91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Python中利用Process創建進程

發布時間:2021-01-25 14:56:33 來源:億速云 閱讀:96 作者:Leah 欄目:開發技術

這篇文章給大家介紹怎么在Python中利用Process創建進程,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

Python multiprocessing 模塊提供了 Process 類,該類可用來在 Windows 平臺上創建新進程。和使用 Thread 類創建多線程方法類似,使用 Process 類創建多進程也有以下 2 種方式:

直接創建 Process 類的實例對象,由此就可以創建一個新的進程;

通過繼承 Process 類的子類,創建實例對象,也可以創建新的進程。注意,繼承 Process 類的子類需重寫父類的 run() 方法。

不僅如此,Process 類中也提供了一些常用的屬性和方法,如表 1 所示。

屬性名或方法名功能
run()第 2 種創建進程的方式需要用到,繼承類中需要對方法進行重寫,該方法中包含的是新進程要執行的代碼。
start()和啟動子線程一樣,新創建的進程也需要手動啟動,該方法的功能就是啟動新創建的線程。
join([timeout])和 thread 類 join() 方法的用法類似,其功能是在多進程執行過程,其他進程必須等到調用 join() 方法的進程執行完畢(或者執行規定的 timeout 時間)后,才能繼續執行;
is_alive()判斷當前進程是否還活著。
terminate()中斷該進程。
name屬性可以為該進程重命名,也可以獲得該進程的名稱。
daemon和守護線程類似,通過設置該屬性為 True,可將新建進程設置為“守護進程”。
pid返回進程的 ID 號。大多數操作系統都會為每個進程配備唯一的 ID 號。

表 1 Python Process類常用屬性和方法

接下來將一一對創建進程的 2 種方法做詳細的講解。

通過Process類創建進程

和使用 thread 類創建子線程的方式非常類似,使用 Process 類創建實例化對象,其本質是調用該類的構造方法創建新進程。Process 類的構造方法格式如下:

def __init__(self,group=None,target=None,name=None,args=(),kwargs={})

其中,各個參數的含義為:

  • group:該參數未進行實現,不需要傳參;

  • target:為新建進程指定執行任務,也就是指定一個函數;

  • name:為新建進程設置名稱;

  • args:為 target 參數指定的參數傳遞非關鍵字參數;

  • kwargs:為 target 參數指定的參數傳遞關鍵字參數。

下面程序演示了如何用 Process 類創建新進程。

from multiprocessing import Process
import os
print("當前進程ID:",os.getpid())
# 定義一個函數,準備作為新進程的 target 參數
def action(name,*add):
 print(name)
 for arc in add:
  print("%s --當前進程%d" % (arc,os.getpid()))
if __name__=='__main__':
 #定義為進程方法傳入的參數
 my_tuple = ("http://jb51.net/python/",\
    "http://jb51.net/shell/",\
    "http://jb51.net/java/")
 #創建子進程,執行 action() 函數
 my_process = Process(target = action, args = ("my_process進程",*my_tuple))
 #啟動子進程
 my_process.start()
 #主進程執行該函數
 action("主進程",*my_tuple)

程序執行結果為:
當前進程ID: 12980
主進程
http://jb51.net/python/ --當前進程12980
http://jb51.net/shell/ --當前進程12980
http://jb51.net/java/ --當前進程12980
當前進程ID: 12860
my_process進程
http://jb51.net/python/ --當前進程12860
http://jb51.net/shell/ --當前進程12860
http://jb51.net/java/ --當前進程12860

需要說明的是,通過 multiprocessing.Process 來創建并啟動進程時,程序必須先判斷 if __name__=='__main__':,否則運行該程序會引發異常。

此程序中有 2 個進程,分別為主進程和我們創建的新進程,主進程會執行整個程序,而子進程不會執行 if __name__ == '__main__' 中包含的程序,而是先執行此判斷語句之外的所有可執行程序,然后再執行我們分配讓它的任務(也就是通過 target 參數指定的函數)。

通過Process繼承類創建進程

和使用 thread 子類創建線程的方式類似,除了直接使用 Process 類創建進程,還可以通過創建 Process 的子類來創建進程。

需要注意的是,在創建 Process 的子類時,需在子類內容重寫 run() 方法。實際上,該方法所起到的作用,就如同第一種創建方式中 target 參數執行的函數。

另外,通過 Process 子類創建進程,和使用 Process 類一樣,先創建該類的實例對象,然后調用 start() 方法啟動該進程。下面程序演示如何通過 Process 子類創建一個進程。

from multiprocessing import Process
import os
print("當前進程ID:",os.getpid())
# 定義一個函數,供主進程調用
def action(name,*add):
 print(name)
 for arc in add:
  print("%s --當前進程%d" % (arc,os.getpid()))
#自定義一個進程類
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" % (arc,os.getpid()))
if __name__=='__main__':
 #定義為進程方法傳入的參數
 my_tuple = ("http://jb51.net/python/",\
    "http://jb51.net/shell/",\
    "http://jb51.net/java/")
 my_process = My_Process("my_process進程",*my_tuple)
 #啟動子進程
 my_process.start()
 #主進程執行該函數
 action("主進程",*my_tuple)

程序執行結果為:
當前進程ID: 22240
主進程
http://jb51.net/python/ --當前進程22240
http://jb51.net/shell/ --當前進程22240
http://jb51.net/java/ --當前進程22240
當前進程ID: 18848
my_process進程
http://jb51.net/python/ --當前進程18848
http://jb51.net/shell/ --當前進程18848
http://jb51.net/java/ --當前進程18848

顯然,該程序的運行結果與上一個程序的運行結果大致相同,它們只是創建進程的方式略有不同而已。
推薦讀者使用第一種方式來創建進程,因為這種方式不僅編程簡單,而且進程直接包裝 target 函數,具有更清晰的邏輯結構。

關于怎么在Python中利用Process創建進程就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

浮山县| 太湖县| 济源市| 通州市| 类乌齐县| 常宁市| 田东县| 河东区| 孟村| 独山县| 荣成市| 宁陕县| 林芝县| 兰考县| 凭祥市| 滦南县| 原平市| 五家渠市| 泾源县| 兴仁县| 广昌县| 东乌| 贵州省| 全州县| 夏邑县| 泸水县| 台南县| 连城县| 宝兴县| 丹棱县| 姚安县| 邵武市| 菏泽市| 瑞昌市| 东港市| 清镇市| 同仁县| 威海市| 新平| 丰顺县| 榆社县|