開啟子進(jìn)程的兩種方式,以及join方法

方式一

在windows系統(tǒng)上,開啟子進(jìn)程的操作必須放到:

if name == 'main':的子代碼中

from multiprocessing import Process
import time


def task(name):
    print('%s is running...' % name)
    time.sleep(3)
    print('%s is done' % name)


if __name__ == '__main__':
    p = Process(target=task, args=('子進(jìn)程...',))
    p.start()
    print('主進(jìn)程...')

方式二

from multiprocessing import Process
import time


class MyProcess(Process):
    def __init__(self, name):
        super().__init__()
        self.name = name

    def run(self):
        print('%s is running...' % self.name)
        time.sleep(3)
        print('%s is done' % self.name)


if __name__ == '__main__':
    p = MyProcess('子進(jìn)程...')
    p.start()
    print('主進(jìn)程...')

join方法

join:讓主進(jìn)程在原地等待,等待子進(jìn)程運行完畢,不會影響子進(jìn)程的執(zhí)行
from multiprocessing import Process
import time

def task(name,n):
    print('%s is running' %name)
    time.sleep(n)
    print('%s is done' %name)

if __name__ == '__main__':
    """
    p1=Process(target=task,args=('子1',1))
    p2=Process(target=task,args=('子2',2))
    p3=Process(target=task,args=('子3',3))

    start=time.time()
    p1.start()
    p2.start()
    p3.start()

    p3.join()
    p1.join()
    p2.join()
    print('主',(time.time()-start))
    """
    start=time.time()
    p_l=[]
    for i in range(1,4):
        p = Process(target=task, args=('子%s' %i, i))
        p_l.append(p)
        p.start()

    for p in p_l:
        p.join()
    print('主', (time.time() - start))

驗證:進(jìn)程之間內(nèi)存空間相互隔離

from multiprocessing import Process

n=100
def task():
    global n
    n=0

if __name__ == '__main__':
    p=Process(target=task)
    p.start()
    p.join()
    print(n)

打印 n 發(fā)現(xiàn) n 的值還是為100 ,說明子進(jìn)程內(nèi)的更改并不會影響到主進(jìn)程的內(nèi)存空間,也就是說明了進(jìn)程之間的內(nèi)存空間相互隔離

進(jìn)程對象其他相關(guān)的屬性或方法

1. 進(jìn)程pid:每一個進(jìn)程在操作系統(tǒng)內(nèi)都有一個唯一的id號,稱之為pid
from multiprocessing import Process,current_process
import time

def task():
    print('%s is running' %current_process().pid)
    time.sleep(30)
    print('%s is done' %current_process().pid)

if __name__ == '__main__':
    p=Process(target=task)
    p.start()
    print('主',current_process().pid)

上下兩種不同的寫法

from multiprocessing import Process,current_process
import time,os

def task():
    print('%s is running 爹是:%s' %(os.getpid(),os.getppid()))
    time.sleep(30)
    print('%s is done 爹是:%s' %(os.getpid(),os.getppid()))


if __name__ == '__main__':
    p=Process(target=task)
    p.start()
    print('主:%s 主他爹:%s' %(os.getpid(),os.getppid()))
2. 進(jìn)程對象其他相關(guān)的屬性或方法
from multiprocessing import Process,current_process
import time,os

def task():
    print('%s is running 爹是:%s' %(os.getpid(),os.getppid()))
    time.sleep(30)
    print('%s is done 爹是:%s' %(os.getpid(),os.getppid()))


if __name__ == '__main__':
    p=Process(target=task,name='子進(jìn)程1')
    p.start()
    # print(p.name)
    p.terminate()
    # time.sleep(0.1)
    print(p.is_alive())
    print('主:%s 主他爹:%s' %(os.getpid(),os.getppid()))
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末挑辆,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子士复,更是在濱河造成了極大的恐慌鹦付,老刑警劉巖当凡,帶你破解...
    沈念sama閱讀 212,080評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡洒宝,警方通過查閱死者的電腦和手機(jī)讶踪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,422評論 3 385
  • 文/潘曉璐 我一進(jìn)店門芯侥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事柱查±螅” “怎么了?”我有些...
    開封第一講書人閱讀 157,630評論 0 348
  • 文/不壞的土叔 我叫張陵唉工,是天一觀的道長研乒。 經(jīng)常有香客問我,道長淋硝,這世上最難降的妖魔是什么雹熬? 我笑而不...
    開封第一講書人閱讀 56,554評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮谣膳,結(jié)果婚禮上竿报,老公的妹妹穿的比我還像新娘。我一直安慰自己继谚,他們只是感情好仰楚,可當(dāng)我...
    茶點故事閱讀 65,662評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著犬庇,像睡著了一般僧界。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上臭挽,一...
    開封第一講書人閱讀 49,856評論 1 290
  • 那天捂襟,我揣著相機(jī)與錄音,去河邊找鬼欢峰。 笑死葬荷,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的纽帖。 我是一名探鬼主播宠漩,決...
    沈念sama閱讀 39,014評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼懊直!你這毒婦竟也來了扒吁?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,752評論 0 268
  • 序言:老撾萬榮一對情侶失蹤室囊,失蹤者是張志新(化名)和其女友劉穎雕崩,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體融撞,經(jīng)...
    沈念sama閱讀 44,212評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡盼铁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,541評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了尝偎。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饶火。...
    茶點故事閱讀 38,687評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡鹏控,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出肤寝,到底是詐尸還是另有隱情牧挣,我是刑警寧澤,帶...
    沈念sama閱讀 34,347評論 4 331
  • 正文 年R本政府宣布醒陆,位于F島的核電站瀑构,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏刨摩。R本人自食惡果不足惜寺晌,卻給世界環(huán)境...
    茶點故事閱讀 39,973評論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望澡刹。 院中可真熱鬧呻征,春花似錦、人聲如沸罢浇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,777評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嚷闭。三九已至攒岛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胞锰,已是汗流浹背灾锯。 一陣腳步聲響...
    開封第一講書人閱讀 32,006評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留嗅榕,地道東北人顺饮。 一個月前我還...
    沈念sama閱讀 46,406評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像凌那,于是被迫代替她去往敵國和親兼雄。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,576評論 2 349

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

  • 一帽蝶、C語言基礎(chǔ) 1赦肋、struct 的內(nèi)存對齊和填充問題其實只要記住一個概念和三個原則就可以了: 一個概念:自然對齊...
    XDgbh閱讀 2,203評論 1 38
  • 1.內(nèi)存的頁面置換算法 (1)最佳置換算法(OPT)(理想置換算法):從主存中移出永遠(yuǎn)不再需要的頁面麦锯;如無這樣的...
    杰倫哎呦哎呦閱讀 3,235評論 1 9
  • 親愛的清馨 第一封信寫給您 您是最懂我的人 也是最了解我的人 你是我的好閨密 也是我的好姐妹 我是最崇拜您的人 也...
    愛粉閱讀 259評論 4 8
  • 本文譯自medium上由UX Design Collective發(fā)布的系列文章,該系列共有九篇琅绅,本次為第五篇扶欣。 系...
    7win7閱讀 183評論 0 2
  • 我一聽氣吐干凈了就能沉到水里,一下來情緒了,站起來料祠,跑到潛水那邊自己偷偷去試了一下骆捧,誰也沒注意我,我跳到水里后吐氣...
    水東方閱讀 344評論 1 0