本篇文章為大家展示了什么是Python中的多進程,代碼簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

我們提供的服務有:做網站、成都網站設計、微信公眾號開發(fā)、網站優(yōu)化、網站認證、蒙山ssl等。為千余家企事業(yè)單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的蒙山網站制作公司
多進程 multiprocessing
由于Python是跨平臺的,自然也應該提供一個跨平臺的多進程支持。multiprocessing模塊就是跨平臺版本的多進程模塊。
multiprocessing模塊提供了一個Process類來代表一個進程對象。
Unix/Linux操作系統提供了一個fork()系統調用,它非常特殊。普通的函數調用,調用一次,返回一次,但是fork()調用一次,返回兩次,因為操作系統自動把當前進程(稱為父進程)復制了一份(稱為子進程),然后,分別在父進程和子進程內返回。
子進程永遠返回0,而父進程返回子進程的ID。這樣做的理由是,一個父進程可以fork出很多子進程,所以,父進程要記下每個子進程的ID,而子進程只需要調用getppid()就可以拿到父進程的ID。
Python的os模塊封裝了常見的系統調用,其中就包括fork,可以在Python程序中輕松創(chuàng)建子進程:
import os
print('Process (%s) start...' % os.getpid())
# Only works on Unix/Linux/Mac:
pid = os.fork()
if pid == 0:
print('I am child process (%s) and my parent is %s.' % (os.getpid(), os.getppid()))
else:
print('I (%s) just created a child process (%s).' % (os.getpid(), pid))運行結果如下:
Process (69673) start ... I (69673) just created a child Process(69674) I am child proces (69674) and my parent is 69673.
有了fork調用,一個進程在接到新任務時就可以復制出一個子進程來處理新任務,常見的Apache服務器就是由父進程監(jiān)聽端口,每當有新的http請求時,就fork出子進程來處理新的http請求。
但是這個fork在windows操作系統是沒有的。于是出現了處理fork的通用模塊,以保證在不同操作系統間的調用。
multiprocessing模塊就是跨平臺版本的多進程模塊。
multiprocessing模塊提供了一個Process類來代表一個進程對象,下面的例子演示了啟動一個子進程并等待其結束:
#!/usr/bin/env python
# coding=utf-8
from multiprocessing import Process
import os
"""
子進程要執(zhí)行的代碼
"""
def run_proc(name):
print('Run child process %s (%s)' % (name, os.getpid()))
if __name__ == '__main__':
print('Parent process %s.' % os.getpid())
p = Process(target=run_proc, args=('test_code',))
print('Child process will start.')
p.start()
p.join()
print('Child process end.')執(zhí)行結果如下:
$ python forkbymutilprocessing.py Parent process 70227. Child process will start. Run child process test_code (70228) Child process end.
創(chuàng)建子進程時,只需要傳入一個執(zhí)行函數和函數的參數,創(chuàng)建一個Process實例,用start()方法啟動,這樣創(chuàng)建進程比fork()還要簡單。
join()方法可以等待子進程結束后再繼續(xù)往下運行,通常用于進程間的同步。
上述內容就是什么是Python中的多進程,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯行業(yè)資訊頻道。
分享題目:什么是Python中的多進程
分享URL:http://chinadenli.net/article10/ghoodo.html
成都網站建設公司_創(chuàng)新互聯,為您提供自適應網站、網站策劃、ChatGPT、軟件開發(fā)、企業(yè)建站、全網營銷推廣
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯