這篇文章主要介紹了python中使用多進(jìn)程編程的示例,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)總部坐落于成都市區(qū),致力網(wǎng)站建設(shè)服務(wù)有成都網(wǎng)站設(shè)計、成都做網(wǎng)站、網(wǎng)絡(luò)營銷策劃、網(wǎng)頁設(shè)計、網(wǎng)站維護(hù)、公眾號搭建、成都小程序開發(fā)、軟件開發(fā)等為企業(yè)提供一整套的信息化建設(shè)解決方案。創(chuàng)造真正意義上的網(wǎng)站建設(shè),為互聯(lián)網(wǎng)品牌在互動行銷領(lǐng)域創(chuàng)造價值而不懈努力!在并發(fā)編程的時候,多線程和多進(jìn)程是經(jīng)常會被使用的兩種模式(此外還有協(xié)程等)。由于 CPython 的 GIL 限制(Jython 和 IronPython 沒有 GIL,PyPy 在嘗試去掉 GIL),只有獲取了 GIL 的線程才能使用 CPU,所以除了需要處理一些可能會阻塞的 IO(讀寫文件、訪問網(wǎng)絡(luò)等)之外,基本沒人會去使用 CPython 的多線程。因此,本文就來說說更有用的 Python 多進(jìn)程編程。
本文描述的環(huán)境為 Linux 操作系統(tǒng)(也適用于大部分 POSIX 系統(tǒng))下的 CPython,可能不適用于 Windows操作系統(tǒng)或其他的Python 實現(xiàn)。
為了避免歧義,下文用「主進(jìn)程」或「當(dāng)前進(jìn)程」表示創(chuàng)建子進(jìn)程的那個進(jìn)程,而不使用「父進(jìn)程」,除非明確指明了「xx 的父進(jìn)程」。
與多線程編程時需要傳遞一個 callable 對象不同的是,多進(jìn)程編程的時候,是將主進(jìn)程復(fù)制到子進(jìn)程,并不能直接要求子進(jìn)程執(zhí)行某個 callable 對象。
在 POSIX 系統(tǒng)中,這個復(fù)制操作是由 clone() 和 fork() 系統(tǒng)調(diào)用來完成的,一般主要使用后者。
如果 fork() 執(zhí)行成功的話,會分別在主進(jìn)程和子進(jìn)程中返回子進(jìn)程的 PID 和 0,然后執(zhí)行代碼就開始不同了。如果失敗的話(內(nèi)存不夠、PID 達(dá)到上限等),子進(jìn)程就不會創(chuàng)建,主進(jìn)程會返回 -1,errno 會被設(shè)置為對應(yīng)的錯誤碼。
在 CPython 的實現(xiàn)中,os.fork() 主要是對 fork() 函數(shù)的封裝,差別在于失敗時拋出 OSError,該異常的 errno 屬性是對應(yīng)的錯誤碼。
因此,多進(jìn)程的 Python 代碼大致會長成這樣:
import os try: pid = os.fork() if pid == 0: # 子進(jìn)程 # 子進(jìn)程的代碼 else: # 主進(jìn)程 # 主進(jìn)程的代碼 except OSError: # 主進(jìn)程處理 fork 失敗的代碼
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享python中使用多進(jìn)程編程的示例內(nèi)容對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,詳細(xì)的解決方法等著你來學(xué)習(xí)!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。