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修改字典內(nèi)key對(duì)應(yīng)值的方法
這篇文章主要介紹了python修改字典內(nèi)key對(duì)應(yīng)值的方法,涉及Python中字典賦值的相關(guān)實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07python實(shí)現(xiàn)圖書(shū)館研習(xí)室自動(dòng)預(yù)約功能
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)圖書(shū)館研習(xí)室自動(dòng)預(yù)約功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04Python中random模塊生成隨機(jī)數(shù)詳解
本文給大家匯總了一下在Python中random模塊中最常用的生成隨機(jī)數(shù)的方法,有需要的小伙伴可以參考下2016-03-03如何使用pyinstaller打包時(shí)引入自己編寫的庫(kù)
這篇文章主要介紹了如何使用pyinstaller打包時(shí)引入自己編寫的庫(kù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02pyinstaller通過(guò)spec文件打包py程序的步驟
這篇文章主要介紹了pyinstaller通過(guò)spec文件打包py程序,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05