這篇文章主要介紹了Python中用fork()函數生成的子進程,分析子進程與父進程的執行順序,需要的朋友可以參考下
python的os module中有fork()函數用於生成子進程,生成的子進程是父進程的鏡像,但是它們有各自的地址空間,子進程復制一份父進程內存給自己,兩個進程之 間的執行是相互獨立的,其執行順序可以是不確定的、隨機的、不可預測的,這點與多線程的執行順序相似。
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 import os def child(): print 'A new child:', os.getpid() print 'Parent id is:', os.getppid() os._exit(0) def parent(): while True: newpid=os.fork() print newpid if newpid==0: child() else: pids=(os.getpid(),newpid) print "parent:%d,child:%d"%pids print "parent parent:",os.getppid() if raw_input()=='q': break parent()在我們加載了os模塊之後,我們parent函數中fork()函數生成了一個子進程,返回值newpid有兩個,一個為0,用以表示子進程,一個是大於 0的整數,用以表示父進程,這個常數正是子進程的pid. 通過print語句我們可以清晰看到兩個返回值。如果fork()返回值是一個負值,則表明子進程生成不成功(這個簡單程序中沒有考慮這種情況)。如果 newpid==0,則表明我們進入到了子進程,也就是child()函數中,在子進程中我們輸出了自己的id和父進程的id。如果進入了else語句, 則表明newpid>0,我們進入到父進程中,在父進程中os.getpid()得到自己的id,fork()返回值newpid表示了子進程的id,同時我們輸出了父進程的父進程的id. 通過實驗我們可以看到if和else語句的執行順序是不確定的,子、父進程的執行順序由操作系統的調度算法來決定。