先看下面這段代碼:
import os
def main():
for i in range(0, 2):
os.fork()
print 'Hello'
if __name__ == '__main__':
main()
猜測(cè)一下,會(huì)輸出幾行Hello。
答案是:
Hello
Hello
Hello
Hello
Hello
Hello
6行!為什么呢?
首先,你要明白o(hù)s.fork()創(chuàng)建的子進(jìn)程會(huì)接著下一行代碼繼續(xù)執(zhí)行,它有返回值,返回值可以為0表示子進(jìn)程或者大于0表示父進(jìn)程pid,os.getpid()返回的是當(dāng)前進(jìn)程的pid,那么我們?cè)俑母妮敵鰜?lái)看得更直觀一些吧:
import os
def main():
for i in range(0, 2):
pid = os.fork()
print "Hello", i, os.getpid(), pid
if __name__ == '__main__':
main()
輸出是這樣的:
Hello 0 9760 9761
Hello 0 9761 0
Hello 1 9760 9762
Hello 1 9762 0
Hello 1 9761 9763
Hello 1 9763 0
這就很容易解釋了:
第一輪循環(huán) ,父進(jìn)程創(chuàng)建了一個(gè)子進(jìn)程P1然后打印,子進(jìn)程P1接著下面的代碼運(yùn)行,打印。之后進(jìn)入第二輪循環(huán);
第二輪循環(huán) ,父進(jìn)程創(chuàng)建了一個(gè)子進(jìn)程P2然后打印,子進(jìn)程P2接著下面的代碼運(yùn)行,打印。子進(jìn)程P1再創(chuàng)建了一個(gè)子進(jìn)程P12然后打印,子進(jìn)程P12接著下面的代碼運(yùn)行,打印。之后循環(huán)結(jié)束,共打印六次。
如果進(jìn)行3輪循環(huán)打印多少次呢,答案是14次,讀者可以自行驗(yàn)證一下。
水平有限,如有錯(cuò)誤歡迎指正!
以上這篇python os.fork() 循環(huán)輸出方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元

