多進(jìn)程

多進(jìn)程簡(jiǎn)單理解:

進(jìn)程之間是獨(dú)立的,是操作系統(tǒng)自己來(lái)維護(hù)和管理的,python通過(guò)C接口起了一個(gè)進(jìn)程,多進(jìn)程可以充分的利用多核CPU

  • 多進(jìn)程的創(chuàng)建:
"""
multiprocessing模塊式python為開(kāi)發(fā)多進(jìn)程提供跨平臺(tái)的模塊模塊式python為開(kāi)發(fā)多進(jìn)程提供跨平臺(tái)的模塊
"""
from multiprocessing import Process
#參數(shù)可有可無(wú)
def run(path,name):
    #while True:
    for i in range(100):
        print("唱歌去",path,name)

if __name__ == "__main__":
    print("程序開(kāi)始運(yùn)行....")
    #target屬性 指向執(zhí)行的函數(shù)(傳遞)汹买,不是調(diào)用返回值
    #創(chuàng)建獨(dú)立的進(jìn)程對(duì)象(可以開(kāi)辟多個(gè)對(duì)象)
    task1 = Process(target=run,args=("ktv","唱吧"))
    #啟動(dòng)進(jìn)程
    task1.start()
    task2 = Process(target=run,args=("去酒吧","sssss"))
    task2.start()
    print("程序運(yùn)行結(jié)束")
多進(jìn)程間的通信:

進(jìn)程間獨(dú)立,如果想相互訪問(wèn),就必須有一個(gè)中間翻譯,下面提供了幾種進(jìn)程間通信的方法

  • 進(jìn)程Queue
#import queue
from multiprocessing import Process,Queue

#子進(jìn)程唆途,內(nèi)存獨(dú)立阎曹,相當(dāng)于數(shù)據(jù)的傳遞
def x(subQueue):
    subQueue.put("呵呵")

if __name__ == "__main__":
    #進(jìn)程Queue
    q = Queue()
    #創(chuàng)建進(jìn)程
    p = Process(target=f,args=(q,))
    #執(zhí)行進(jìn)程
    p.start()
    print(q.get())
"""
Queue通信蝶押,相當(dāng)于父進(jìn)程賦值了一個(gè)Queue給子進(jìn)程,
子進(jìn)程在這個(gè)Queue放好數(shù)據(jù)后缀蹄,序列化一個(gè)中間翻譯螺戳,
然后在反序列化返回給父進(jìn)程醋旦,
因?yàn)檫M(jìn)程之間內(nèi)存獨(dú)立,不能傳遞對(duì)象咒劲,傳遞的其實(shí)是序列化的數(shù)據(jù)
"""
  • Pipe:
    多進(jìn)程有一種傳遞方式叫管道顷蟆,它的原理和Queue相同
from multiprocessing import Process,Pipe

#定義子進(jìn)程執(zhí)行
def x(Subconn):
    Subconn.send("成績(jī)出來(lái)了嗎")
    print("這個(gè)是父親的詢問(wèn):",Subconn.recv())
    Subconn.close()

if __name__ == "__main__":
#創(chuàng)建管道兩端
    parent_conn,child_conn = Pipe()
#創(chuàng)建子進(jìn)程
    p = Process(target = x.argst =(child_conn,))
    p.start()     #控制流程
    print("l來(lái)自兒子的問(wèn)候:",parent_conn.recv())
    parent_conn.send("出來(lái)了腐魂,不怎么好")
    p.join()
進(jìn)程鎖:

雖然內(nèi)存獨(dú)立,但是即使是打印也會(huì)造成打印數(shù)據(jù)錯(cuò)誤,為了防止進(jìn)程間搶屏幕打印輸出,加了進(jìn)程鎖

from multiprocessing import Process,Lock

#定義子進(jìn)程執(zhí)行
def x (lock,num)
    lock.acquire()
    print("哈哈帐偎,嘻嘻,嘿嘿",num)
    lock.release

if __name__ == "__main__":
    lock = Lock()
#循環(huán)創(chuàng)建50個(gè)子進(jìn)程
    for num in range(50):
        Process(target = x, args=(lock,num)).start()
進(jìn)程池:

當(dāng)我們需要的進(jìn)程數(shù)量不多的時(shí)候蛔屹,我們可以使用multiprocessing的Process類來(lái)創(chuàng)建進(jìn)程削樊。但是如果我們需要的進(jìn)程特別多的時(shí)候,手動(dòng)創(chuàng)建工作量太大了兔毒,所以Python也為我們提供了Pool(池)的方式來(lái)創(chuàng)建大量進(jìn)程漫贞。

from multiprocessing import Pool
import os,time

def run(msg):
    print("開(kāi)始一個(gè)子線程運(yùn)行了……")
    time.sleep(1)
    print("開(kāi)始一個(gè)子線程運(yùn)行結(jié)束了……")

if __name__ == "__main__":
    pool = Pool(3)  # 表示初始化一個(gè)進(jìn)程池,最大進(jìn)程數(shù)為3
    for x in range(10):
        pool.apply_async(run, args=("hello pool",))
    print("------start----")
    pool.close() # 關(guān)閉池
    pool.join() # 等待所有的子進(jìn)程完成育叁,必須放在close后面
    print("-------end------")
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末绕辖,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子擂红,更是在濱河造成了極大的恐慌仪际,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件昵骤,死亡現(xiàn)場(chǎng)離奇詭異树碱,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)变秦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門成榜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蹦玫,你說(shuō)我怎么就攤上這事赎婚×跣澹” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,931評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵挣输,是天一觀的道長(zhǎng)纬凤。 經(jīng)常有香客問(wèn)我,道長(zhǎng)撩嚼,這世上最難降的妖魔是什么停士? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,218評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮完丽,結(jié)果婚禮上恋技,老公的妹妹穿的比我還像新娘。我一直安慰自己逻族,他們只是感情好蜻底,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著聘鳞,像睡著了一般朱躺。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上搁痛,一...
    開(kāi)封第一講書(shū)人閱讀 51,198評(píng)論 1 299
  • 那天长搀,我揣著相機(jī)與錄音,去河邊找鬼鸡典。 笑死源请,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的彻况。 我是一名探鬼主播谁尸,決...
    沈念sama閱讀 40,084評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼纽甘!你這毒婦竟也來(lái)了良蛮?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,926評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤悍赢,失蹤者是張志新(化名)和其女友劉穎决瞳,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體左权,經(jīng)...
    沈念sama閱讀 45,341評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡皮胡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了赏迟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片屡贺。...
    茶點(diǎn)故事閱讀 39,731評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出甩栈,到底是詐尸還是另有隱情泻仙,我是刑警寧澤,帶...
    沈念sama閱讀 35,430評(píng)論 5 343
  • 正文 年R本政府宣布量没,位于F島的核電站玉转,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏允蜈。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評(píng)論 3 326
  • 文/蒙蒙 一蒿柳、第九天 我趴在偏房一處隱蔽的房頂上張望饶套。 院中可真熱鬧,春花似錦垒探、人聲如沸妓蛮。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,676評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蛤克。三九已至,卻和暖如春夷蚊,著一層夾襖步出監(jiān)牢的瞬間构挤,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,829評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工惕鼓, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留筋现,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,743評(píng)論 2 368
  • 正文 我出身青樓箱歧,卻偏偏與公主長(zhǎng)得像矾飞,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子呀邢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評(píng)論 2 354

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