Python fork創(chuàng)建進(jìn)程

1、進(jìn)程

進(jìn)程是程序的一次動(dòng)態(tài)執(zhí)行過程,它對(duì)應(yīng)了從代碼加載、執(zhí)行到執(zhí)行完畢的一個(gè)完整過程。進(jìn)程是系統(tǒng)進(jìn)行資源分配和調(diào)度的一個(gè)獨(dú)立單位。進(jìn)程是由代碼(堆棧段)、數(shù)據(jù)(數(shù)據(jù)段)、內(nèi)核狀態(tài)和一組寄存器組成。 在多任務(wù)操作系統(tǒng)中,通過運(yùn)行多個(gè)進(jìn)程來并發(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è)用戶程序不能直接訪問這些數(shù)據(jù)。

進(jìn)程的狀態(tài):創(chuàng)建、準(zhǔn)備、運(yùn)行、阻塞、結(jié)束。

2、創(chuàng)建進(jìn)程

Linux 和 Unix 操作系統(tǒng)提供了一個(gè)fork()函數(shù)創(chuàng)建新的進(jìn)程,這也就意為這該函數(shù)僅適用于Linux和Unix平臺(tái),Windows操作系統(tǒng)沒有fork()函數(shù)。

fork()函數(shù)比較特殊,python的os.fork()是唯一調(diào)用一次返回兩次的函數(shù),因操作系統(tǒng)將當(dāng)前的進(jìn)程(父進(jìn)程)復(fù)制了一份新的進(jìn)程(子進(jìn)程),然后分別在父進(jìn)程和子進(jìn)程內(nèi)返回。

例:利用fork()函數(shù)創(chuàng)建子進(jìn)程

利用fork()函數(shù)創(chuàng)建子進(jìn)程

os.fork()創(chuàng)建子進(jìn)程后,ret會(huì)返回兩個(gè)值。

例:查看ret的值

ret的值如果大于0,代表當(dāng)前進(jìn)程是主進(jìn)程,如果ret的值等于0,代表當(dāng)前進(jìn)程是子進(jìn)程。

例:調(diào)整進(jìn)程執(zhí)行順序

此時(shí),父進(jìn)程運(yùn)行結(jié)束后,顯示終端待輸入命令,但是子進(jìn)程沒有運(yùn)行結(jié)束,當(dāng)子進(jìn)程運(yùn)行結(jié)束之后,就會(huì)打印子進(jìn)程中的語句。

例:后面如果有語句,是否會(huì)執(zhí)行

if之后的語句不論是主進(jìn)程還是子進(jìn)程都會(huì)正常執(zhí)行,主進(jìn)程與子進(jìn)程都會(huì)執(zhí)行程序中的所有代碼。

3、查看主進(jìn)程與子進(jìn)程的進(jìn)程號(hào)

例:查看主進(jìn)程與子進(jìn)程的進(jìn)程號(hào)

查看主進(jìn)程與子進(jìn)程進(jìn)程號(hào)

os.getpid()函數(shù)會(huì)返回當(dāng)前進(jìn)程的進(jìn)程號(hào),os.getppid()函數(shù)會(huì)返回當(dāng)前進(jìn)程的父進(jìn)程的進(jìn)程號(hào)。

當(dāng)os.fork()函數(shù)的返回值大于0時(shí),此時(shí)的值會(huì)當(dāng)做當(dāng)前進(jìn)程的子進(jìn)程的ID號(hào),如果Python解釋器判斷當(dāng)前進(jìn)程被占用,會(huì)依次向下尋找能夠使用的ID號(hào)返回,所以子進(jìn)程的進(jìn)程號(hào)與父進(jìn)程的ret返回值相同。子進(jìn)程中的父進(jìn)程號(hào)與主進(jìn)程的進(jìn)程號(hào)相同。

4、全局變量在父子進(jìn)程中不共享

如果定義了全局變量,那么在父子進(jìn)程中,該全局變量是獨(dú)立的,不會(huì)互相影響。

例:全局變量在父子進(jìn)程中不共享

全局變量父子進(jìn)程中不共享

5、多個(gè)fork

例:多個(gè)fork

多個(gè)fork

使用fork()函數(shù)創(chuàng)建進(jìn)程會(huì)占用大量的內(nèi)存空間,容易造成fork()炸彈,同時(shí)父子進(jìn)程之間是不會(huì)相互影響的,父進(jìn)程或子進(jìn)程結(jié)束時(shí),另一個(gè)進(jìn)程會(huì)正常運(yùn)行,直到程序結(jié)束。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容