Python进程学习笔记-进程创建fork
生活随笔
收集整理的這篇文章主要介紹了
Python进程学习笔记-进程创建fork
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. 進程 VS 程序
編寫完畢的代碼,在沒有運行的時候,稱之為程序
正在運行著的代碼,就成為進程
進程,除了包含代碼以外,還有需要運行的環境等,所以和程序是有區別的。
2. fork( )
Python的os模塊封裝了常見的系統調用,其中就包括fork,可以在Python程序中輕松創建子進程:
import os# 注意,fork函數,只在Unix/Linux/Mac上運行,windows不可以pid = os.fork()if pid == 0:print('哈哈1') # 子進程,pid=0else:print('哈哈2')說明:
- 程序執行到os.fork()時,操作系統會創建一個新的進程(子進程),然后復制父進程的所有信息到子進程中
- 然后父進程和子進程都會從fork()函數中得到一個返回值,在子進程中這個值一定是0,而父進程中是子進程的 id號
在Unix/Linux操作系統中,提供了一個fork()系統函數,它非常特殊。
普通的函數調用,調用一次,返回一次,但是fork()調用一次,返回兩次,因為操作系統自動把當前進程(稱為父進程)復制了一份(稱為子進程),然后,分別在父進程和子進程內返回。
子進程永遠返回0,而父進程返回子進程的ID。
這樣做的理由是,一個父進程可以fork出很多子進程,所以,父進程要記下每個子進程的ID,而子進程只需要調用getppid()就可以拿到父進程的ID。
?
3. getpid()、getppid()
import osrpid = os.fork() if rpid<0:print("fork調用失敗。") elif rpid == 0:print("我是子進程(%s),我的父進程是(%s)"%(os.getpid(),os.getppid()))x+=1 else:print("我是父進程(%s),我的子進程是(%s)"%(os.getpid(),rpid))print("父子進程都可以執行這里的代碼")運行結果:
我是父進程(19360),我的子進程是(19361) 父子進程都可以執行這里的代碼 我是子進程(19361),我的父進程是(19360) 父子進程都可以執行這里的代碼?
轉載于:https://www.cnblogs.com/Paul-watermelon/articles/9723285.html
總結
以上是生活随笔為你收集整理的Python进程学习笔记-进程创建fork的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java.lang.IllegalAcc
- 下一篇: Centos7.5虚拟机无法ping通网