python中fork创建新的进程
為了了解其中工作原理, 在結合linux的查看進程ps命令,對進程做了進一步的理解:
1、在linux下運行.py文件,系統(tǒng)就會創(chuàng)建一個進程
# coding=utf-8 from time import sleep sleep(30)在linux終端下執(zhí)行命令:
python /home/lilong/桌面/fork_using.py &加上&符號,可以讓程序在后臺運行,不會占用終端。輸入ps -l命令查看進程,顯示如下:
運行.py之前輸入ps -l 顯示如下:
可以看出運行后創(chuàng)建了一個新的進程
2、使用fork來創(chuàng)建一個新進程
使用fork創(chuàng)建一個新進程成功后,新進程會是原進程的子進程,原進程稱為父進程。如果發(fā)生錯誤,則會拋出OSError異常。
Unix/Linux操作系統(tǒng)提供了一個fork()系統(tǒng)調用,它非常特殊。普通的函數調用,調用一次,返回一次,但是fork()調用一次,返回兩次,因為操作系統(tǒng)自動把當前進程(稱為父進程)復制了一份(稱為子進程),然后,分別在父進程和子進程內返回。子進程永遠返回0,而父進程返回子進程的ID。這樣做的理由是,一個父進程可以fork出很多子進程,所以,父進程要記下每個子進程的ID,而子進程只需要調用getppid()就可以拿到父進程的ID。
代碼:
# coding=utf-8 from time import sleep import os try:pid=os.fork() except OSError(e):passsleep(30)運行結果:
可以看出產生了一個新的子進程
其中fork的具體流程:
使用fork創(chuàng)建子進程后,子進程會復制父進程的數據信息,而后程序就分兩個進程繼續(xù)運行后面的程序,這也是fork(分叉)名字的含義了。在子進程內,這個方法會返回0;在父進程內,這個方法會返回子進程的編號PID。可以使用PID來區(qū)分兩個進程:
運行:
首先fork()出一個子進程,但父進程還在執(zhí)行,所以打印出num=10,同時子進程也在執(zhí)行,由于要等待10秒,所以后打印出的應該是num=9,之所以打印兩次就是因為fork()調用一次,返回兩次。
參考:
http://www.01happy.com/python-fork-create-process/
http://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/001431927781401bb47ccf187b24c3b955157bb12c5882d000
總結
以上是生活随笔為你收集整理的python中fork创建新的进程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 农行信用币验证失败
- 下一篇: 工行信用卡还款有宽限期吗