Java開發者的Python快速進修指南:網路編程及併發編程

来源:https://www.cnblogs.com/guoxiaoyu/archive/2023/11/27/17845120.html
-Advertisement-
Play Games

今天我們學習了網路編程和多線程技術的寫法區別。我們主要關註了在Java中使用socket和多線程結合實現伺服器處理多個客戶端連接的阻塞IO的方法,以及在Python中使用multiprocessing模塊創建多線程的方式。通過一個實例來說明瞭這些概念,並指出了需要註意的問題。其實瞭解了這些基本用法後... ...


今天我們將對網路編程和多線程技術進行講解,這兩者的原理大家都已經瞭解了,因此我們主要關註的是它們的寫法區別。雖然這些區別並不是非常明顯,但我們之所以將網路編程和多線程一起講解,是因為在學習Java的socket知識時,我們通常會將它們結合使用,以實現伺服器對多個客戶端連接的阻塞IO的處理。雖然我是這樣解釋的,但是Python在控制連接數方面更加友好,相對於Java來說更加便捷。好了,廢話不多說,讓我們開始今天的講解吧。

socket及線程

這裡我將給大家舉一個例子,同時也會指出一些需要註意的問題,以幫助Java同學們避免再次遇到這些坑。

import socket
import multiprocessing
import time

# 創建互斥鎖
lock = multiprocessing.Lock()


# 處理客戶端請求的函數
def handle_client(conn, addr):
    print(f"Connected to {addr}")
    time.sleep(100)



# 創建伺服器
def create_server():
    # 創建socket對象
    server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

    # 綁定地址和埠
    server_addr = ("localhost", 8000)
    server_socket.bind(server_addr)

    # 監聽連接
    server_socket.listen(1)
    print("Server started. Listening for connections...")

    while True:
        # 接受客戶端連接
        conn, addr = server_socket.accept()
        handle_client(conn, addr)
        # 創建進程處理客戶端請求
        process = multiprocessing.Process(target=handle_client, args=(conn, addr))
        process.start()

if __name__ == '__main__':
    # 啟動伺服器
    print("啟動伺服器")
    create_server()

以下是客戶端的代碼:

import socket
import time
client = socket.socket() #創建socket對象
host = '127.0.0.1' #服務端ip
port = 8000 #服務端ip埠
client.connect((host, port)) #根據服務端地址,建立連接
print('client對象:', client) #查看socket對象屬性
time.sleep(100)

#client.close() #關閉與服務端的連接

上面的例子已經涵蓋了我今天要講的內容,所以沒有太多需要補充的了。不過,我可以談一下與Java的一些區別。

首先,Python使用multiprocessing來創建多線程,當然還有其他的包可以實現相同的功能,這裡就不一一贅述了。另外,還有一個需要註意的地方是,在Python中使用if __name__ == '__main__':語句時,你必須將其寫在主函數中,而不要寫在你定義的子函數中。為什麼要這樣寫呢?原因是,當調用process.start()後,Python會重新執行當前文件,也就是說如果你將if __name__ == '__main__':這句話寫在非主函數中,create_server()它將會被再次調用。而使用if __name__ == '__main__':語句可以判斷是否是主函數執行,如果不是,則會過濾掉這部分代碼。雖然這個機制可能有些令人困惑,但是去深入瞭解其執行原理並不是必要的,所以大家要記住這個要點。這張圖顯示的是再次被調用是的名字:

image

第二:在Python官網中指出,通過調用server_socket.listen(1)可以啟動一個伺服器,用於接受連接並將未接受的客戶端連接放入等待隊列中。需要註意的是,等待隊列的大小由listen(n)中的參數n+1指定,並不代表實際監聽到的客戶端連接。如果超過隊列大小的連接嘗試進入,伺服器將直接報錯。

image

總結

今天我們學習了網路編程和多線程技術的寫法區別。我們主要關註了在Java中使用socket和多線程結合實現伺服器處理多個客戶端連接的阻塞IO的方法,以及在Python中使用multiprocessing模塊創建多線程的方式。通過一個實例來說明瞭這些概念,並指出了需要註意的問題。其實瞭解了這些基本用法後,我們還能夠自己實現許多其他功能,例如瞭解了線程之後,就知道會有隊列的概念,然後可以嘗試自己實現一個生產者消費者隊列。這與學習Java的路線非常相似,並且我們擁有豐富的開發經驗,因此我們只需要關註語法方面的學習即可~~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Redis以其速度而聞名。 1 業務數據緩存 1.1 通用數據緩存 string,int,list,map。Redis 最常見的用例是緩存對象以加速 Web 應用程式。 此用例中,Redis 將頻繁請求的數據存儲在記憶體。允許 Web 伺服器快速返回頻繁訪問的數據。這減輕資料庫的負載並提高應用程式RT ...
  • 在Flask框架中,實現Token認證機制並不是一件複雜的事情。除了使用官方提供的`flask_httpauth`模塊或者第三方模塊`flask-jwt`,我們還可以考慮自己實現一個簡易版的Token認證工具。自定義Token認證機制的本質是生成一個令牌(Token),併在用戶每次請求時驗證這個令牌... ...
  • 公眾號「架構成長指南」,專註於生產實踐、雲原生、分散式系統、大數據技術分享。 目的 Spring Cloud 線上微服務實例都是2個起步,如果出問題後,在沒有ELK等日誌分析平臺,如何確定調用到了目標服務的那個實例,以此來排查問題 效果 可以看到服務有幾個實例是上線,並且最終調用了那個實例 考慮到S ...
  • 原文: https://openaigptguide.com/what-is-openai/ OpenAI 是一家人工智慧研究公司,成立於2015年,總部位於美國舊金山。目前,OpenAI由創始人Sam Altman、首席技術官Ilya Sutskever、首席執行官Ilya Sutskever(同 ...
  • Flask 框架提供了強大的 Session 模塊組件,為 Web 應用實現用戶註冊與登錄系統提供了方便的機制。結合 Flask-WTF 表單組件,我們能夠輕鬆地設計出用戶友好且具備美觀界面的註冊和登錄頁面,使這一功能能夠直接應用到我們的項目中。本文將深入探討如何通過 Flask 和 Flask-W... ...
  • 作者:京東零售 薑波 來源:京東雲開發者社區 各位小伙伴在字元串拼接時應該都見過下麵這種提示: 內容翻譯:報告StringBuffer、StringBuilder或StringJoiner的任何用法,這些用法可以用單個java.lang.String串聯來替換。使用字元串串聯可以使代碼更短、更簡單。 ...
  • JsonPath是一種能夠提取部分JSON文檔屬性、對象、數組的語法,支持條件過濾、數學運算、字元串處理等功能。JsonPath與JSON文檔就像 XPath 表達式與 XML 文檔結合使用一樣。 ...
  • 這段筆記詳細介紹了SpringMVC控制器開發的不同方面,主要圍繞控制器如何接收客戶端請求參數展開討論。它包括了不同接收請求參數的方式,從基於Servlet API的方式到簡單變數、POJO對象、一組簡單變數、一組POJO對象的接收方式,以及@RequestParam註解的使用方法。還涉及了中文請求... ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...