Python多進(jìn)程fork()函數(shù)詳解
進(jìn)程
進(jìn)程是程序的一次動(dòng)態(tài)執(zhí)行過(guò)程,它對(duì)應(yīng)了從代碼加載、執(zhí)行到執(zhí)行完畢的一個(gè)完整過(guò)程。進(jìn)程是系統(tǒng)進(jìn)行資源分配和調(diào)度的一個(gè)獨(dú)立單位。進(jìn)程是由代碼(堆棧段)、數(shù)據(jù)(數(shù)據(jù)段)、內(nèi)核狀態(tài)和一組寄存器組成。
在多任務(wù)操作系統(tǒng)中,通過(guò)運(yùn)行多個(gè)進(jìn)程來(lái)并發(fā)地執(zhí)行多個(gè)任務(wù)。由于每個(gè)線程都是一個(gè)能獨(dú)立執(zhí)行自身指令的不同控制流,因此一個(gè)包含多個(gè)線程的進(jìn)程也能夠?qū)崿F(xiàn)進(jìn)程內(nèi)多任務(wù)的并發(fā)執(zhí)行。
進(jìn)程是一個(gè)內(nèi)核級(jí)的實(shí)體,進(jìn)程結(jié)構(gòu)的所有成分都在內(nèi)核空間中,一個(gè)用戶程序不能直接訪問(wèn)這些數(shù)據(jù)。
進(jìn)程的狀態(tài):
創(chuàng)建、準(zhǔn)備、運(yùn)行、阻塞、結(jié)束。
進(jìn)程間的通信方式可以有:
- 文件
- 管道
- socket
- 信號(hào)
- 信號(hào)量
- 共享內(nèi)存
要讓Python程序?qū)崿F(xiàn)多進(jìn)程(multiprocessing),必須先了解操作系統(tǒng)的相關(guān)知識(shí)。
在Unix/Linux操作系統(tǒng)提供了一個(gè)fork()函數(shù),它非常特殊,調(diào)用一次,返回兩次,因?yàn)椴僮飨到y(tǒng)將當(dāng)前的進(jìn)程(父進(jìn)程)復(fù)制了一份(子進(jìn)程),然后分別在父進(jìn)程和子進(jìn)程內(nèi)返回。
Python中的進(jìn)程
- os.fork()
- subprocess
- processing
- multiprocessing
fork()函數(shù)
函數(shù)原型:
Help on built-in function fork in module posix: fork(...) fork() -> pid Fork a child process. Return 0 to child process and PID of child to parent process.
從fork()函數(shù)原型來(lái)看,它也屬于一個(gè)內(nèi)建函數(shù)。
子進(jìn)程永遠(yuǎn)返回0,而父進(jìn)程返回子進(jìn)程的ID。這樣做的理由是,一個(gè)父進(jìn)程可以fork()出很多子進(jìn)程,所以,父進(jìn)程要記下每個(gè)子進(jìn)程的ID,而子進(jìn)程只需要調(diào)用getppid()就可以拿到父進(jìn)程的ID。
Python的進(jìn)程函數(shù)fork()是在os模塊,下面是一個(gè)關(guān)于進(jìn)程的例子:
import os print os.getpid() #獲取子進(jìn)程的進(jìn)程號(hào) pid = os.fork() if pid == 0 : print 'I am child process (%s) and my parent is %s.' % (os.getpid(), os.getppid()) else : print 'I (%s) just created a child process (%s).' % (os.getpid(), pid)
執(zhí)行結(jié)果:
1526
I (1526) just created a child process (1527).
I am child process (1527) and my parent is 1526.
有了fork調(diào)用,一個(gè)進(jìn)程在接到新的任務(wù)時(shí),就可以復(fù)制出一個(gè)子進(jìn)程來(lái)處理新任務(wù)。常見(jiàn)的Apache服務(wù)器就是由父進(jìn)程監(jiān)聽(tīng)端口,一旦有新的http請(qǐng)求時(shí),就fork出子進(jìn)程來(lái)處理新的http請(qǐng)求。
再看一個(gè)例子:
#coding=utf-8 import os os.fork() print 1
執(zhí)行結(jié)果:
1
1
程序中,父進(jìn)程中創(chuàng)建了一個(gè)子進(jìn)程,子進(jìn)程運(yùn)行打印了一個(gè)1,回到父進(jìn)程又打印了一個(gè)1,所以結(jié)果是打印了2個(gè)1。
需要注意的是,上面創(chuàng)建進(jìn)程的函數(shù)都是Unix/Linux下的,Windows下是沒(méi)有的,那在Windows下又使用什么實(shí)現(xiàn)多進(jìn)程呢?
由于Python是跨平臺(tái)的,自然也應(yīng)該提供一個(gè)跨平臺(tái)的多進(jìn)程支持。multiprocessing模塊就是跨平臺(tái)版本的多進(jìn)程模塊, 支持子進(jìn)程、通信和共享數(shù)據(jù)、執(zhí)行不同形式的同步。
multiprocessing模塊提供了一個(gè)Process類來(lái)創(chuàng)建一個(gè)新的進(jìn)程對(duì)象。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
python+opencv實(shí)現(xiàn)動(dòng)態(tài)物體追蹤
這篇文章主要為大家詳細(xì)介紹了python+opencv實(shí)現(xiàn)動(dòng)態(tài)物體的追蹤,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Python爬取英雄聯(lián)盟MSI直播間彈幕并生成詞云圖
很開(kāi)心RNG最近在英雄聯(lián)盟季中賽奪冠了,特地爬取了直播間彈幕并生成詞云圖,大家一起開(kāi)心一下,看看奪冠時(shí)大家都在說(shuō)什么,需要的朋友可以參考下2021-06-06
python得到一個(gè)excel的全部sheet標(biāo)簽值方法
今天小編就為大家分享一篇python得到一個(gè)excel的全部sheet標(biāo)簽值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
python爬蟲(chóng)入門(mén)教程之點(diǎn)點(diǎn)美女圖片爬蟲(chóng)代碼分享
這篇文章主要介紹了python爬蟲(chóng)入門(mén)教程之點(diǎn)點(diǎn)美女圖片爬蟲(chóng)代碼分享,本文以采集抓取點(diǎn)點(diǎn)網(wǎng)美女圖片為例,需要的朋友可以參考下2014-09-09
讓python的Cookie.py模塊支持冒號(hào)做key的方法
雖然Cookie的標(biāo)準(zhǔn)是不允許:冒號(hào)出現(xiàn)在key里面的,但是我們的開(kāi)發(fā)人員是很可愛(ài)的,常常會(huì)讓我們意想不到。2010-12-12
python內(nèi)置模塊collections知識(shí)點(diǎn)總結(jié)
這篇文章主要介紹了python內(nèi)置模塊collections知識(shí)點(diǎn)總結(jié),有興趣的朋友們學(xué)習(xí)下。2019-12-12

