Python創建進程、執行緒的兩種方式
程式碼創建進程和執行緒的兩種方式
"""
定心丸:Python創建進程和執行緒的方式基本都是一致的,包括其中的調用方法等,學會一個
另一個自然也就會了。
"""
1.創建進程的兩種方式
-
方式一
import os import time from multiprocessing import Process # 實例化一個multiprocessing.Process的對象,並傳入一個初始化函數對象 def task(name): print(f'進程 {name} 的PID為{os.getpid()},父進程ID為 {os.getppid()}') time.sleep(2) print(f'進程 {name} 的PID為{os.getpid()} 運行結束') if __name__ == '__main__': # 此處要注意,windows下開啟進程一定要在main方法下開啟 process1 = Process(target=task, args=('1',)) process2 = Process(target=task, args=('2',)) # 啟動進程 process1.start() # 告訴作業系統幫你創建一個進程 process2.start() print(f'主進程 {os.getpid()}')
-
方式二
import os import time from multiprocessing import Process # 繼承類的方式去創建 class MyProcess(Process): def __init__(self, name): # 繼承Process中的__init__() super(MyProcess, self).__init__() self.name = name # 此處必要在該類中創建run方法 重寫run方法 def run(self): print(f'進程 {self.name} 的PID為{os.getpid()},父進程ID為 {os.getppid()}') time.sleep(2) print(f'進程 {self.name} 的PID為{os.getpid()} 運行結束') if __name__ == '__main__': # 創建兩個進程 process1 = MyProcess('1') process2 = MyProcess('2') # 開啟這兩個進程 process1.start() process2.start() print(f'主進程 {os.getpid()}')
運行結果如下:
""" 主進程 2776 進程 1 的PID為9364,父進程ID為 2776 進程 2 的PID為4140,父進程ID為 2776 進程 1 的PID為9364 運行結束進程 2 的PID為4140 運行結束 """
2.創建執行緒的兩種方式
-
方式一
import time from threading import Thread # 實例化一個multiprocessing.Process的對象,並傳入一個初始化函數對象 def task(name): print(f"執行緒 {name} is running") time.sleep(2) print(f"執行緒 {name} is over") if __name__ == '__main__': # 開啟執行緒不需要在main下面執行程式碼,直接書寫就可以 # 但是還是習慣性的將啟動命令寫在main下面 # 創建兩個執行緒 thead1 = Thread(target=task, args=('1',)) thead2 = Thread(target=task, args=('2',)) # 開啟兩個執行緒 thead1.start() # 創建執行緒的開銷非常小,幾乎程式碼一執行執行緒就創建了 thead2.start() print("主")
-
方式二
import time from threading import Thread # 繼承類的方式去創建 class MyThead(Thread): def __init__(self, name): # 繼承Process中的__init__() super(MyThead, self).__init__() self.name = name # 此處必要在該類中創建run方法 重寫run方法 def run(self): print(f"執行緒 {self.name} is running") time.sleep(2) print(f"執行緒 {self.name} is over") if __name__ == '__main__': # 創建兩個執行緒 thead1 = MyThead('1') thead2 = MyThead('1') # 開啟這兩個執行緒 thead1.start() thead2.start() print('主')
-
輸出結果為如下:
""" 執行緒 1 is running 主 執行緒 2 is running 執行緒 1 is over執行緒 2 is over """
上方只是簡單的創建進程和執行緒,以上注釋只是個人理解,不足的地方還望見諒,歡迎補充