屬性名或方法名 | 功能 |
---|---|
run() | 第 2 種創(chuàng)建進(jìn)程的方式需要用到,繼承類中需要對(duì)方法進(jìn)行重寫,該方法中包含的是新進(jìn)程要執(zhí)行的代碼。 |
start() | 和啟動(dòng)子線程一樣,新創(chuàng)建的進(jìn)程也需要手動(dòng)啟動(dòng),該方法的功能就是啟動(dòng)新創(chuàng)建的線程。 |
join([timeout]) | 和 thread 類 join() 方法的用法類似,其功能是在多進(jìn)程執(zhí)行過程,其他進(jìn)程必須等到調(diào)用 join() 方法的進(jìn)程執(zhí)行完畢(或者執(zhí)行規(guī)定的 timeout 時(shí)間)后,才能繼續(xù)執(zhí)行; |
is_alive() | 判斷當(dāng)前進(jìn)程是否還活著。 |
terminate() | 中斷該進(jìn)程。 |
name屬性 | 可以為該進(jìn)程重命名,也可以獲得該進(jìn)程的名稱。 |
daemon | 和守護(hù)線程類似,通過設(shè)置該屬性為 True,可將新建進(jìn)程設(shè)置為“守護(hù)進(jìn)程”。 |
pid | 返回進(jìn)程的 ID 號(hào)。大多數(shù)操作系統(tǒng)都會(huì)為每個(gè)進(jìn)程配備唯一的 ID 號(hào)。 |
表 1 Python Process類常用屬性和方法
接下來將一一對(duì)創(chuàng)建進(jìn)程的 2 種方法做詳細(xì)的講解。
和使用 thread 類創(chuàng)建子線程的方式非常類似,使用 Process 類創(chuàng)建實(shí)例化對(duì)象,其本質(zhì)是調(diào)用該類的構(gòu)造方法創(chuàng)建新進(jìn)程。Process 類的構(gòu)造方法格式如下:
def __init__(self,group=None,target=None,name=None,args=(),kwargs={})
其中,各個(gè)參數(shù)的含義為:
下面程序演示了如何用 Process 類創(chuàng)建新進(jìn)程。
from multiprocessing import Process import os print("當(dāng)前進(jìn)程ID:",os.getpid()) # 定義一個(gè)函數(shù),準(zhǔn)備作為新進(jìn)程的 target 參數(shù) def action(name,*add): print(name) for arc in add: print("%s --當(dāng)前進(jìn)程%d" % (arc,os.getpid())) if __name__=='__main__': #定義為進(jìn)程方法傳入的參數(shù) my_tuple = ("http://jb51.net/python/",\ "http://jb51.net/shell/",\ "http://jb51.net/java/") #創(chuàng)建子進(jìn)程,執(zhí)行 action() 函數(shù) my_process = Process(target = action, args = ("my_process進(jìn)程",*my_tuple)) #啟動(dòng)子進(jìn)程 my_process.start() #主進(jìn)程執(zhí)行該函數(shù) action("主進(jìn)程",*my_tuple)
程序執(zhí)行結(jié)果為:
當(dāng)前進(jìn)程ID: 12980
主進(jìn)程
http://jb51.net/python/ --當(dāng)前進(jìn)程12980
http://jb51.net/shell/ --當(dāng)前進(jìn)程12980
http://jb51.net/java/ --當(dāng)前進(jìn)程12980
當(dāng)前進(jìn)程ID: 12860
my_process進(jìn)程
http://jb51.net/python/ --當(dāng)前進(jìn)程12860
http://jb51.net/shell/ --當(dāng)前進(jìn)程12860
http://jb51.net/java/ --當(dāng)前進(jìn)程12860
需要說明的是,通過 multiprocessing.Process 來創(chuàng)建并啟動(dòng)進(jìn)程時(shí),程序必須先判斷 if __name__=='__main__':,否則運(yùn)行該程序會(huì)引發(fā)異常。
此程序中有 2 個(gè)進(jìn)程,分別為主進(jìn)程和我們創(chuàng)建的新進(jìn)程,主進(jìn)程會(huì)執(zhí)行整個(gè)程序,而子進(jìn)程不會(huì)執(zhí)行 if __name__ == '__main__' 中包含的程序,而是先執(zhí)行此判斷語句之外的所有可執(zhí)行程序,然后再執(zhí)行我們分配讓它的任務(wù)(也就是通過 target 參數(shù)指定的函數(shù))。
和使用 thread 子類創(chuàng)建線程的方式類似,除了直接使用 Process 類創(chuàng)建進(jìn)程,還可以通過創(chuàng)建 Process 的子類來創(chuàng)建進(jìn)程。
需要注意的是,在創(chuàng)建 Process 的子類時(shí),需在子類內(nèi)容重寫 run() 方法。實(shí)際上,該方法所起到的作用,就如同第一種創(chuàng)建方式中 target 參數(shù)執(zhí)行的函數(shù)。
另外,通過 Process 子類創(chuàng)建進(jìn)程,和使用 Process 類一樣,先創(chuàng)建該類的實(shí)例對(duì)象,然后調(diào)用 start() 方法啟動(dòng)該進(jìn)程。下面程序演示如何通過 Process 子類創(chuàng)建一個(gè)進(jìn)程。
from multiprocessing import Process import os print("當(dāng)前進(jìn)程ID:",os.getpid()) # 定義一個(gè)函數(shù),供主進(jìn)程調(diào)用 def action(name,*add): print(name) for arc in add: print("%s --當(dāng)前進(jìn)程%d" % (arc,os.getpid())) #自定義一個(gè)進(jìn)程類 class My_Process(Process): def __init__(self,name,*add): super().__init__() self.name = name self.add = add def run(self): print(self.name) for arc in self.add: print("%s --當(dāng)前進(jìn)程%d" % (arc,os.getpid())) if __name__=='__main__': #定義為進(jìn)程方法傳入的參數(shù) my_tuple = ("http://jb51.net/python/",\ "http://jb51.net/shell/",\ "http://jb51.net/java/") my_process = My_Process("my_process進(jìn)程",*my_tuple) #啟動(dòng)子進(jìn)程 my_process.start() #主進(jìn)程執(zhí)行該函數(shù) action("主進(jìn)程",*my_tuple)
程序執(zhí)行結(jié)果為:
當(dāng)前進(jìn)程ID: 22240
主進(jìn)程
http://jb51.net/python/ --當(dāng)前進(jìn)程22240
http://jb51.net/shell/ --當(dāng)前進(jìn)程22240
http://jb51.net/java/ --當(dāng)前進(jìn)程22240
當(dāng)前進(jìn)程ID: 18848
my_process進(jìn)程
http://jb51.net/python/ --當(dāng)前進(jìn)程18848
http://jb51.net/shell/ --當(dāng)前進(jìn)程18848
http://jb51.net/java/ --當(dāng)前進(jìn)程18848
顯然,該程序的運(yùn)行結(jié)果與上一個(gè)程序的運(yùn)行結(jié)果大致相同,它們只是創(chuàng)建進(jìn)程的方式略有不同而已。
推薦讀者使用第一種方式來創(chuàng)建進(jìn)程,因?yàn)檫@種方式不僅編程簡單,而且進(jìn)程直接包裝 target 函數(shù),具有更清晰的邏輯結(jié)構(gòu)。
到此這篇關(guān)于Python Process創(chuàng)建進(jìn)程的2種方法詳解的文章就介紹到這了,更多相關(guān)Python Process創(chuàng)建進(jìn)程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:秦皇島 百色 綏化 合肥 綿陽 周口 周口 淮安
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python Process創(chuàng)建進(jìn)程的2種方法詳解》,本文關(guān)鍵詞 Python,Process,創(chuàng)建,進(jìn)程,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。