溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python中使用多進(jìn)程編程的示例

發(fā)布時(shí)間:2020-11-17 11:30:49 來(lái)源:億速云 閱讀:128 作者:小新 欄目:編程語(yǔ)言

這篇文章主要介紹了python中使用多進(jìn)程編程的示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

在并發(fā)編程的時(shí)候,多線程和多進(jìn)程是經(jīng)常會(huì)被使用的兩種模式(此外還有協(xié)程等)。由于 CPython 的 GIL 限制(Jython 和 IronPython 沒(méi)有 GIL,PyPy 在嘗試去掉 GIL),只有獲取了 GIL 的線程才能使用 CPU,所以除了需要處理一些可能會(huì)阻塞的 IO(讀寫(xiě)文件、訪問(wèn)網(wǎng)絡(luò)等)之外,基本沒(méi)人會(huì)去使用 CPython 的多線程。因此,本文就來(lái)說(shuō)說(shuō)更有用的 Python 多進(jìn)程編程。

本文描述的環(huán)境為 Linux 操作系統(tǒng)(也適用于大部分 POSIX 系統(tǒng))下的 CPython,可能不適用于 Windows操作系統(tǒng)或其他的Python 實(shí)現(xiàn)。

為了避免歧義,下文用「主進(jìn)程」或「當(dāng)前進(jìn)程」表示創(chuàng)建子進(jìn)程的那個(gè)進(jìn)程,而不使用「父進(jìn)程」,除非明確指明了「xx 的父進(jìn)程」。

與多線程編程時(shí)需要傳遞一個(gè) callable 對(duì)象不同的是,多進(jìn)程編程的時(shí)候,是將主進(jìn)程復(fù)制到子進(jìn)程,并不能直接要求子進(jìn)程執(zhí)行某個(gè) callable 對(duì)象。

在 POSIX 系統(tǒng)中,這個(gè)復(fù)制操作是由 clone() 和 fork() 系統(tǒng)調(diào)用來(lái)完成的,一般主要使用后者。
如果 fork() 執(zhí)行成功的話,會(huì)分別在主進(jìn)程和子進(jìn)程中返回子進(jìn)程的 PID 和 0,然后執(zhí)行代碼就開(kāi)始不同了。如果失敗的話(內(nèi)存不夠、PID 達(dá)到上限等),子進(jìn)程就不會(huì)創(chuàng)建,主進(jìn)程會(huì)返回 -1,errno 會(huì)被設(shè)置為對(duì)應(yīng)的錯(cuò)誤碼。
在 CPython 的實(shí)現(xiàn)中,os.fork() 主要是對(duì) fork() 函數(shù)的封裝,差別在于失敗時(shí)拋出 OSError,該異常的 errno 屬性是對(duì)應(yīng)的錯(cuò)誤碼。

因此,多進(jìn)程的 Python 代碼大致會(huì)長(zhǎng)成這樣:

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)容對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問(wèn)題就找億速云,詳細(xì)的解決方法等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI