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)程

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)


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)程中不共享


5、多個(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é)束。