python多進(jìn)程(multiprocessing)

multiprocessing模塊提供了一個Process類來代表一個進(jìn)程對象,下面的例子演示了啟動一個子進(jìn)程并等待其結(jié)束:

#coding=utf-8
from multiprocessing import Process
import os

# 子進(jìn)程要執(zhí)行的代碼
def run_proc(name):
    print('子進(jìn)程運行中,name= %s ,pid=%d...' % (name, os.getpid()))

if __name__=='__main__':
    print('父進(jìn)程 %d.' % os.getpid())
    p = Process(target=run_proc, args=('test',))
    print('子進(jìn)程將要執(zhí)行')
    p.start()
    p.join()
    print('子進(jìn)程已結(jié)束')

執(zhí)行結(jié)果:


執(zhí)行的結(jié)果

join()方法可以等待子進(jìn)程結(jié)束后再繼續(xù)往下運行,通常用于進(jìn)程間的同步。

<h3>Process語法結(jié)構(gòu)如下:</h3>

Process([group [, target [, name [, args [, kwargs]]]]])

target:表示這個進(jìn)程實例所調(diào)用對象;

args:表示調(diào)用對象的位置參數(shù)元組;

kwargs:表示調(diào)用對象的關(guān)鍵字參數(shù)字典;

name:為當(dāng)前進(jìn)程實例的別名;

group:大多數(shù)情況下用不到;

Process類常用方法:

is_alive():判斷進(jìn)程實例是否還在執(zhí)行;

join([timeout]):是否等待進(jìn)程實例執(zhí)行結(jié)束,或等待多少秒;

start():啟動進(jìn)程實例(創(chuàng)建子進(jìn)程);

run():如果沒有給定target參數(shù),對這個對象調(diào)用start()方法時,就將執(zhí)行對象中的run()方法;

terminate():不管任務(wù)是否完成,立即終止;

Process類常用屬性:

name:當(dāng)前進(jìn)程實例別名,默認(rèn)為Process-N,N為從1開始遞增的整數(shù);

pid:當(dāng)前進(jìn)程實例的PID值;

<h4>實例1</h4>

from multiprocessing import Process
import os
from time import sleep

# 子進(jìn)程要執(zhí)行的代碼
def run_proc(name, age, **kwargs):
    for i in range(10):
        print('子進(jìn)程運行中,name= %s,age=%d ,pid=%d...' % (name, age,os.getpid()))
        print(kwargs)
        sleep(0.5)

if __name__=='__main__':
    print('父進(jìn)程 %d.' % os.getpid())
    p = Process(target=run_proc, args=('test',18), kwargs={"m":20})
    print('子進(jìn)程將要執(zhí)行')
    p.start()
    sleep(1)
    p.terminate()
    p.join()
    print('子進(jìn)程已結(jié)束')

結(jié)果:

父進(jìn)程 21378.
子進(jìn)程將要執(zhí)行
子進(jìn)程運行中,name= test,age=18 ,pid=21379...
{'m': 20}
子進(jìn)程運行中,name= test,age=18 ,pid=21379...
{'m': 20}
子進(jìn)程已結(jié)束

<h4>實例2</h4>

#coding=utf-8
from multiprocessing import Process
import time
import os

#兩個子進(jìn)程將會調(diào)用的兩個方法
def  worker_1(interval):
    print("worker_1,父進(jìn)程(%s),當(dāng)前進(jìn)程(%s)"%(os.getppid(),os.getpid()))
    t_start = time.time()
    time.sleep(interval) #程序?qū)粧炱餴nterval秒
    t_end = time.time()
    print("worker_1,執(zhí)行時間為'%0.2f'秒"%(t_end - t_start))

def  worker_2(interval):
    print("worker_2,父進(jìn)程(%s),當(dāng)前進(jìn)程(%s)"%(os.getppid(),os.getpid()))
    t_start = time.time()
    time.sleep(interval)
    t_end = time.time()
    print("worker_2,執(zhí)行時間為'%0.2f'秒"%(t_end - t_start))

#輸出當(dāng)前程序的ID
print("進(jìn)程ID:%s"%os.getpid())

#創(chuàng)建兩個進(jìn)程對象,target指向這個進(jìn)程對象要執(zhí)行的對象名稱,
#args后面的元組中,是要傳遞給worker_1方法的參數(shù),
#因為worker_1方法就一個interval參數(shù),這里傳遞一個整數(shù)2給它,
#如果不指定name參數(shù),默認(rèn)的進(jìn)程對象名稱為Process-N,N為一個遞增的整數(shù)
p1=Process(target=worker_1,args=(2,))
p2=Process(target=worker_2,name="dongGe",args=(1,))

#使用"進(jìn)程對象名稱.start()"來創(chuàng)建并執(zhí)行一個子進(jìn)程,
#這兩個進(jìn)程對象在start后,就會分別去執(zhí)行worker_1和worker_2方法中的內(nèi)容
p1.start()
p2.start()

#同時父進(jìn)程仍然往下執(zhí)行,如果p2進(jìn)程還在執(zhí)行,將會返回True
print("p2.is_alive=%s"%p2.is_alive())

#輸出p1和p2進(jìn)程的別名和pid
print("p1.name=%s"%p1.name)
print("p1.pid=%s"%p1.pid)
print("p2.name=%s"%p2.name)
print("p2.pid=%s"%p2.pid)

#join括號中不攜帶參數(shù),表示父進(jìn)程在這個位置要等待p1進(jìn)程執(zhí)行完成后,
#再繼續(xù)執(zhí)行下面的語句,一般用于進(jìn)程間的數(shù)據(jù)同步,如果不寫這一句,
#下面的is_alive判斷將會是True,在shell(cmd)里面調(diào)用這個程序時
#可以完整的看到這個過程,大家可以嘗試著將下面的這條語句改成p1.join(1),
#因為p2需要2秒以上才可能執(zhí)行完成,父進(jìn)程等待1秒很可能不能讓p1完全執(zhí)行完成,
#所以下面的print會輸出True,即p1仍然在執(zhí)行
p1.join()
print("p1.is_alive=%s"%p1.is_alive())

輸出結(jié)果:

進(jìn)程ID:19866
p2.is_alive=True
p1.name=Process-1
p1.pid=19867
p2.name=dongGe
p2.pid=19868
worker_1,父進(jìn)程(19866),當(dāng)前進(jìn)程(19867)
worker_2,父進(jìn)程(19866),當(dāng)前進(jìn)程(19868)
worker_2,執(zhí)行時間為'1.00'秒
worker_1,執(zhí)行時間為'2.00'秒
p1.is_alive=False
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,825評論 6 546
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,814評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,980評論 0 384
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 64,064評論 1 319
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,779評論 6 414
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,109評論 1 330
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,099評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,287評論 0 291
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,799評論 1 338
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,515評論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,750評論 1 375
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,221評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,933評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,327評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,667評論 1 296
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,492評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,703評論 2 380

推薦閱讀更多精彩內(nèi)容

  • 簡介 multiprocessing包是python中用來提供多進(jìn)程管理的包,能完全利用電腦的多核功能。在Unix...
    aialin閱讀 1,439評論 0 4
  • 1.進(jìn)程 1.1多線程的引入 現(xiàn)實生活中 有很多的場景中的事情是同時進(jìn)行的,比如開車的時候手和腳共同來駕駛汽車,再...
    TENG書閱讀 513評論 0 0
  • Python 多進(jìn)程 multiprocessing.Pool類詳解 multiprocessing模塊 mult...
    很少更新了閱讀 10,125評論 2 14
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,836評論 18 139
  • 一場夢,不覺長 醒來已日上三竿。 夢回高中 身著校服在校園游蕩。 校門前出現(xiàn)古老的蒸汽火車 和各種游樂園景象。 粉...
    可樂飛冰閱讀 291評論 0 0