新聞中心
除可以進(jìn)行多線程編程之外,Python 還支持使用多進(jìn)程來實(shí)現(xiàn)并發(fā)編程。

創(chuàng)新互聯(lián)長期為上1000+客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為鎮(zhèn)雄企業(yè)提供專業(yè)的成都網(wǎng)站建設(shè)、成都做網(wǎng)站,鎮(zhèn)雄網(wǎng)站改版等技術(shù)服務(wù)。擁有十多年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
Python 的 os 模塊提供了一個(gè) fork() 方法,該方法可以 fork 出來一個(gè)子進(jìn)程。簡單來說,fork() 方法的作用在于,程序會啟動兩個(gè)進(jìn)程(一個(gè)是父進(jìn)程,一個(gè)是 fork 出來的子進(jìn)程)來執(zhí)行從 os.fork() 開始的所有代碼。
fork() 方法不需要參數(shù),它有一個(gè)返回值,該返回值表明是哪個(gè)進(jìn)程在執(zhí)行:
如果 fork() 方法返回 0,則表明是 fork 出來的子進(jìn)程在執(zhí)行。
如果 fork() 方法返回非 0,則表明是父進(jìn)程在執(zhí)行,該方法返回 fork() 出來的子進(jìn)程的進(jìn)程 ID。
下面程序示范了使用 fork() 方法創(chuàng)建新進(jìn)程的過程:
import os
print('父進(jìn)程(%s)開始執(zhí)行' % os.getpid())
# 開始fork一個(gè)子進(jìn)程
# 從這行代碼開始,下面代碼都會被兩個(gè)進(jìn)程執(zhí)行
pid = os.fork()
print('進(jìn)程進(jìn)入:%s' % os.getpid())
# 如果pid為0,表明子進(jìn)程
if pid == 0:
print('子進(jìn)程,其ID為 (%s), 父進(jìn)程ID為 (%s)' % (os.getpid(), os.getppid()))
else:
print('我 (%s) 創(chuàng)建的子進(jìn)程ID為 (%s).' % (os.getpid(), pid))
print('進(jìn)程結(jié)束:%s' % os.getpid())
上面程序 fork 出來一個(gè)子進(jìn)程,這意味著程序會分別使用父進(jìn)程和子進(jìn)程來執(zhí)行從此行代碼開始的代碼。
在 Linux 或 Mac OS X 系統(tǒng)上運(yùn)行上面程序(Windows 不支持 fork() 方法,因此在 Windows 系統(tǒng)上運(yùn)行上面程序會報(bào)錨),可以看到如下運(yùn)行結(jié)果:
父進(jìn)程(1795)開始執(zhí)行 進(jìn)程進(jìn)入:1795 我(1795)創(chuàng)建的子進(jìn)程ID 為(1796). 進(jìn)程結(jié)束:1795 進(jìn)程進(jìn)入:1796 子進(jìn)程,其ID 為(1796),父進(jìn)程ID 為(1795) 進(jìn)程結(jié)束: 1796
從上面的運(yùn)行結(jié)果可以看到,此時(shí)程序分別使用兩個(gè)進(jìn)程執(zhí)行從“進(jìn)程進(jìn)入”到“進(jìn)程結(jié)束”之間的代碼,這就是 os.fork() 方法的作用。
在實(shí)際編程中,程序可通過 fork() 方法來創(chuàng)建一個(gè)子進(jìn)程,然后通過判斷 fork() 方法的返回值來確定程序是否正在執(zhí)行子進(jìn)程,也就是把需要并發(fā)執(zhí)行的任務(wù)放在 if pid==0: 的條件執(zhí)行體中,這樣就可以啟動多個(gè)子進(jìn)程來執(zhí)行并發(fā)任務(wù)。
需要注意的是,os.fork() 方法在 Windows 系統(tǒng)上無效,只在 UNIX 及類 UNIX 系統(tǒng)上有效,UNIX 及類 UNIX 系統(tǒng)包括 UNIX、Linux 和 Mac OS X。
當(dāng)前標(biāo)題:創(chuàng)新互聯(lián)Python教程:Pythonfork方法:創(chuàng)建新進(jìn)程
URL地址:http://fisionsoft.com.cn/article/ccccego.html


咨詢
建站咨詢
