python中fork()函式生成子程式分析

pythontab發表於2014-02-08

   python的os module中有fork()函式用於生成子程式,生成的子程式是父程式的映象,但是它們有各自的地址空間,子程式複製一份父程式記憶體給自己,兩個程式之 間的執行是相互獨立的,其執行順序可以是不確定的、隨機的、不可預測的,這點與多執行緒的執行順序相似。  

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語句的執行順序是不確定的,子、父程式的執行順序由操作系統的排程演算法來決定。


相關文章