您好,登錄后才能下訂單哦!
先看下面這段代碼:
import os def main(): for i in range(0, 2): os.fork() print 'Hello' if __name__ == '__main__': main()
猜測一下,會輸出幾行Hello。
答案是:
Hello Hello Hello Hello Hello Hello
6行!為什么呢?
首先,你要明白os.fork()創建的子進程會接著下一行代碼繼續執行,它有返回值,返回值可以為0表示子進程或者大于0表示父進程pid,os.getpid()返回的是當前進程的pid,那么我們再改改輸出來看得更直觀一些吧:
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
這就很容易解釋了:
第一輪循環,父進程創建了一個子進程P1然后打印,子進程P1接著下面的代碼運行,打印。之后進入第二輪循環;
第二輪循環,父進程創建了一個子進程P2然后打印,子進程P2接著下面的代碼運行,打印。子進程P1再創建了一個子進程P12然后打印,子進程P12接著下面的代碼運行,打印。之后循環結束,共打印六次。
如果進行3輪循環打印多少次呢,答案是14次,讀者可以自行驗證一下。
水平有限,如有錯誤歡迎指正!
以上這篇python os.fork() 循環輸出方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。