1店印、進(jìn)程
進(jìn)程是程序的一次動態(tài)執(zhí)行過程,它對應(yīng)了從代碼加載倒慧、執(zhí)行到執(zhí)行完畢的一個完整過程按摘。進(jìn)程是系統(tǒng)進(jìn)行資源分配和調(diào)度的一個獨立單位。進(jìn)程是由代碼(堆棧段)纫谅、數(shù)據(jù)(數(shù)據(jù)段)炫贤、內(nèi)核狀態(tài)和一組寄存器組成。 在多任務(wù)操作系統(tǒng)中付秕,通過運行多個進(jìn)程來并發(fā)地執(zhí)行多個任務(wù)兰珍。由于每個線程都是一個能獨立執(zhí)行自身指令的不同控制流,因此一個包含多個線程的進(jìn)程也能夠?qū)崿F(xiàn)進(jìn)程內(nèi)多任務(wù)的并發(fā)執(zhí)行盹牧。進(jìn)程是一個內(nèi)核級的實體俩垃,進(jìn)程結(jié)構(gòu)的所有成分都在內(nèi)核空間中,一個用戶程序不能直接訪問這些數(shù)據(jù)汰寓。
進(jìn)程的狀態(tài):創(chuàng)建口柳、準(zhǔn)備、運行有滑、阻塞跃闹、結(jié)束。
2毛好、創(chuàng)建進(jìn)程
Linux 和 Unix 操作系統(tǒng)提供了一個fork()函數(shù)創(chuàng)建新的進(jìn)程望艺,這也就意為這該函數(shù)僅適用于Linux和Unix平臺,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會返回兩個值。
例:查看ret的值
ret的值如果大于0风钻,代表當(dāng)前進(jìn)程是主進(jìn)程顷蟀,如果ret的值等于0,代表當(dāng)前進(jìn)程是子進(jìn)程骡技。
例:調(diào)整進(jìn)程執(zhí)行順序
此時鸣个,父進(jìn)程運行結(jié)束后,顯示終端待輸入命令布朦,但是子進(jìn)程沒有運行結(jié)束囤萤,當(dāng)子進(jìn)程運行結(jié)束之后,就會打印子進(jìn)程中的語句喝滞。
例:后面如果有語句阁将,是否會執(zhí)行
if之后的語句不論是主進(jìn)程還是子進(jìn)程都會正常執(zhí)行懊亡,主進(jìn)程與子進(jìn)程都會執(zhí)行程序中的所有代碼队秩。
3捂龄、查看主進(jìn)程與子進(jìn)程的進(jìn)程號
例:查看主進(jìn)程與子進(jìn)程的進(jìn)程號
os.getpid()函數(shù)會返回當(dāng)前進(jìn)程的進(jìn)程號环础,os.getppid()函數(shù)會返回當(dāng)前進(jìn)程的父進(jìn)程的進(jìn)程號桥滨。
當(dāng)os.fork()函數(shù)的返回值大于0時潮针,此時的值會當(dāng)做當(dāng)前進(jìn)程的子進(jìn)程的ID號暖哨,如果Python解釋器判斷當(dāng)前進(jìn)程被占用畏吓,會依次向下尋找能夠使用的ID號返回滚婉,所以子進(jìn)程的進(jìn)程號與父進(jìn)程的ret返回值相同图筹。子進(jìn)程中的父進(jìn)程號與主進(jìn)程的進(jìn)程號相同。
4让腹、全局變量在父子進(jìn)程中不共享
如果定義了全局變量远剩,那么在父子進(jìn)程中,該全局變量是獨立的骇窍,不會互相影響瓜晤。
例:全局變量在父子進(jìn)程中不共享
5、多個fork
例:多個fork
使用fork()函數(shù)創(chuàng)建進(jìn)程會占用大量的內(nèi)存空間腹纳,容易造成fork()炸彈痢掠,同時父子進(jìn)程之間是不會相互影響的,父進(jìn)程或子進(jìn)程結(jié)束時嘲恍,另一個進(jìn)程會正常運行足画,直到程序結(jié)束。