校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 像線程一樣管理進程的Python multiprocessing庫

像線程一樣管理進程的Python multiprocessing庫

熱門標簽:沈陽防封電銷卡品牌 武漢外呼系統平臺 富錦商家地圖標注 沈陽外呼系統呼叫系統 外呼系統哪些好辦 江西省地圖標注 如何申請400電話費用 沈陽人工外呼系統價格 池州外呼調研線路

一、創建一個進程

要創建一個進程,最簡單的方式是用一個目標函數實例化一個Process對象,然后與threading一樣調用start()函數讓它工作。示例如下:

import multiprocessing

def worker():
    for i in range(3):
        print(i)

if __name__=="__main__":
    p = multiprocessing.Process(target=worker)
    p.start()

運行之后,效果如下:

需要注意的是,multiprocessing庫在Windows創建進程必須在if __name__=="__main__":中,這是 Windows 上多進程的實現問題。在 Windows 上,子進程會自動 import 啟動它的這個文件,而在 import 的時候是會執行這些語句的。如果直接創建就會無限遞歸創建子進程報錯。所以必須把創建子進程的部分用那個 if 判斷保護起來,import 的時候 __name__ 不是 __main__ ,就不會遞歸運行了。

二、設置進程名

在threading線程中,我們可以通過其參數name設置線程名,同樣的我們也可以通過name參數設置其進程的名字。示例如下:

import multiprocessing
import time

def worker():
    print(multiprocessing.current_process().name, "start")
    time.sleep(2)
    print(multiprocessing.current_process().name, "end")

if __name__ == "__main__":
    p1 = multiprocessing.Process(name='p1', target=worker)
    p2 = multiprocessing.Process(name='p2', target=worker)
    p3 = multiprocessing.Process(name='p3', target=worker)
    p1.start()
    p2.start()
    p3.start()

運行之后,效果如下:

三、守護進程

和線程一樣,在所有子進程沒有退出之前,主程序是不會退出的。有時候,我們可能需要啟動一個后臺進程,它可以一直運行而不阻塞主程序退出。

要標志一個守護進程,可以將其添加第3個參數daemon,設置為True。默認值為False,不作為守護進程。示例如下:

import multiprocessing
import time

def worker():
    print(multiprocessing.current_process().name, "start")
    time.sleep(1)
    print(multiprocessing.current_process().name, "end")

def worker2():
    print(multiprocessing.current_process().name, "start")
    time.sleep(2)
    print(multiprocessing.current_process().name, "end")

if __name__ == "__main__":
    p1 = multiprocessing.Process(name='p1', target=worker)
    p2 = multiprocessing.Process(name='p2', target=worker2, daemon=True)
    p3 = multiprocessing.Process(name='p3', target=worker2, daemon=True)
    p1.start()
    p2.start()
    p3.start()

運行之后,效果如下:

p2,p3為守護進程,但p1不是所以執行1秒之后,就退出主程序了,也就沒有打印p2p3的內容。但是其依舊在執行中,直到執行完成。

四、join()

同樣的,如果你期望強制等待一個守護進程的結束,可以增加join()函數。還是上面的代碼,示例如下:

import multiprocessing
import time

def worker():
    print(multiprocessing.current_process().name, "start")
    time.sleep(1)
    print(multiprocessing.current_process().name, "end")

def worker2():
    print(multiprocessing.current_process().name, "start")
    time.sleep(2)
    print(multiprocessing.current_process().name, "end")

if __name__ == "__main__":
    p1 = multiprocessing.Process(name='p1', target=worker)
    p2 = multiprocessing.Process(name='p2', target=worker2, daemon=True)
    p3 = multiprocessing.Process(name='p3', target=worker2, daemon=True)
    p1.start()
    p2.start()
    p3.start()
    p1.join()
    p2.join()
    p3.join()

   

運行之后,和設置進程名的運行結果一樣,這里不在展示。唯一與守護進程代碼的區別就是最后三行join()函數代碼。當然,也可以像線程一樣,給join()函數傳入一個時間,超過這個時間,主進程不再等待。

五、強制結束進程

如果一個進程已經掛起或者不小心進入了死鎖狀態,那么這個時候,我們往往會強制的結束進程。對一個進程對象調用terminate()會結束子進程。示例如下:

import multiprocessing
import time

def worker():
    print(multiprocessing.current_process().name, "start")
    time.sleep(5)
    print(multiprocessing.current_process().name, "end")

if __name__ == "__main__":
    p1 = multiprocessing.Process(name='p1', target=worker)
    p1.start()
    print("是否還在運行", p1.is_alive())
    p1.terminate()
    print("是否還在運行", p1.is_alive())
    p1.join()
    print("是否還在運行", p1.is_alive())

運行之后,輸出如下:

終止進程后要使用join()函數等待進程的退出。使進程管理代碼有足夠的時間更新對象的狀態,以反應進程已經終止。

六、進程退出狀態碼

進程退出時,生成的狀態碼可以通過exitcode屬性訪問。下表就是其狀態碼的取值范圍以及其意義:

退出碼 含義
0 未生成任何錯誤
>0 進程有一個錯誤,并以該錯誤碼退出
0 進程以一個-1*exitcodde信號結束

測試如下:

import multiprocessing
import time

def worker():
    print(multiprocessing.current_process().name, "start")
    time.sleep(5)
    print(multiprocessing.current_process().name, "end")

if __name__ == "__main__":
    p1 = multiprocessing.Process(name='p1', target=worker)
    p2 = multiprocessing.Process(name='p2', target=worker)
    p1.start()
    p2.start()
    print("是否還在運行", p1.is_alive())
    p1.terminate()
    print("是否還在運行", p1.is_alive())
    print(p1.exitcode)
    p1.join()
    print("是否還在運行", p1.is_alive())
    print(p1.exitcode)
    time.sleep(5.5)
    print(p2.exitcode)

運行之后,效果如下:

可以看到,強制退出的進程狀態碼為負數,正常退出的進程狀態碼為0。

七、日志

調試并發問題時,如果能夠訪問multiprocessing所提供對象的內部狀態,那么這會很有用。在實際的項目中,我們可以使用一個方便的模塊級函數啟用日志記錄,它使用logging建立一個日志記錄器對象,并增加一個處理器,使日志消息被發送到標準錯誤通道。

示例如下:

import multiprocessing
import logging
import sys

def worker():
    print("運行工作進程")
    sys.stdout.flush()

if __name__ == "__main__":
    multiprocessing.log_to_stderr(logging.DEBUG)
    p1 = multiprocessing.Process(name='p1', target=worker)
    p1.start()
    p1.join()

運行之后,效果如下:

八、派生進程

與線程一樣,我們可以自定義進程,而不必只是傳入一個函數進行進程的創建。

創建的進程的方式也是派生自進程類即可。示例如下:

import multiprocessing

class WorkerProcess(multiprocessing.Process):
    def run(self):
        print(self.name)
        return

if __name__ == "__main__":
    for i in range(5):
        p = WorkerProcess()
        p.start()
        p.join()

運行之后,效果如下:

multiprocessing庫的進程知識與threading一樣長,因為本篇的內容已經夠長了,剩下的知識我們將在下一篇博文中接著講解。

到此這篇關于像線程一樣管理進程的Python multiprocessing庫的文章就介紹到這了,更多相關Python multiprocessing庫內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 分析Python感知線程狀態的解決方案之Event與信號量
  • Python爬蟲之線程池的使用
  • Python多線程編程之threading模塊詳解
  • 深入理解python多線程編程
  • Python一些線程的玩法總結

標簽:黑龍江 呂梁 銅川 株洲 潛江 阿里 常德 通遼

巨人網絡通訊聲明:本文標題《像線程一樣管理進程的Python multiprocessing庫》,本文關鍵詞  像,線程,一樣,管理,進程,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《像線程一樣管理進程的Python multiprocessing庫》相關的同類信息!
  • 本頁收集關于像線程一樣管理進程的Python multiprocessing庫的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲精品一区二区三区精华液 | 不卡视频一二三四| av综合在线播放| 日韩限制级电影在线观看| 最新不卡av在线| 久久99精品久久久久久久久久久久 | 国产ts人妖一区二区| 91精品国产福利| 亚洲精品中文在线影院| 精品亚洲porn| 日韩三级在线免费观看| 亚洲最新视频在线观看| 成人国产视频在线观看| 久久婷婷色综合| 老司机精品视频在线| 色呦呦日韩精品| 国产精品第一页第二页第三页| 天天操天天色综合| 91福利资源站| 亚洲综合色在线| 91国偷自产一区二区开放时间 | 久久综合成人精品亚洲另类欧美| 亚洲一区二区在线视频| 91丨porny丨中文| 中文字幕一区二区三区蜜月 | 欧美亚洲动漫制服丝袜| 日本中文在线一区| 色婷婷久久99综合精品jk白丝| 欧美韩国日本综合| 国产成人99久久亚洲综合精品| 26uuu国产日韩综合| 国内精品国产成人国产三级粉色| 日韩网站在线看片你懂的| 天使萌一区二区三区免费观看| 欧美特级限制片免费在线观看| 洋洋av久久久久久久一区| 色综合久久天天| 一区二区三区不卡视频| 欧美在线制服丝袜| 午夜久久久久久久久久一区二区| 欧洲视频一区二区| 天天综合天天综合色| 欧美一区二区三区免费大片| 老司机一区二区| 国产色一区二区| 99精品欧美一区二区三区小说| 亚洲精品高清在线观看| 欧美肥妇free| 九九在线精品视频| 中文在线免费一区三区高中清不卡| 成人自拍视频在线| 亚洲人成网站精品片在线观看| 91网站黄www| 肉色丝袜一区二区| 一色屋精品亚洲香蕉网站| 色综合色狠狠天天综合色| 亚洲午夜电影在线观看| 欧美一区二区三区小说| 精品一区二区三区久久| 国产精品欧美一区二区三区| 色婷婷综合久久久久中文一区二区 | 精品99一区二区| 成人精品视频一区二区三区尤物| 亚洲精品国产第一综合99久久| 欧美日韩久久一区二区| 国产精品一区二区三区99| 国产精品不卡在线| 欧美三级日韩在线| 国产成人av影院| 亚洲小少妇裸体bbw| 久久综合狠狠综合久久综合88| 91麻豆免费观看| 久久爱www久久做| 亚洲美女视频在线| 欧美大片在线观看一区二区| av网站一区二区三区| 日韩影院免费视频| 亚洲人成在线播放网站岛国| 欧美一区二区三区视频| 7777精品久久久大香线蕉| 国产麻豆欧美日韩一区| 亚洲福利一区二区| 中文字幕中文字幕一区二区| 日韩女优av电影| 欧美午夜电影网| a美女胸又www黄视频久久| 蜜桃av一区二区| 亚洲一区日韩精品中文字幕| 欧美韩国日本一区| 欧美精品一区在线观看| 91精品啪在线观看国产60岁| 99re这里只有精品视频首页| 久久99久久久久| 婷婷夜色潮精品综合在线| 日韩一区日韩二区| 国产午夜精品美女毛片视频| 91精品国产高清一区二区三区蜜臀| 99精品桃花视频在线观看| 国产一区二区看久久| 久久精品国产一区二区三区免费看 | 国产农村妇女毛片精品久久麻豆| 4438x亚洲最大成人网| 日本韩国一区二区三区| 成人97人人超碰人人99| 成人理论电影网| 国产一区二区91| 韩国成人精品a∨在线观看| 视频一区二区中文字幕| 日本中文字幕一区二区有限公司| 亚洲激情av在线| 亚洲精品ww久久久久久p站| 亚洲男女毛片无遮挡| 亚洲精品高清在线| 亚洲综合自拍偷拍| 洋洋av久久久久久久一区| 亚洲一区日韩精品中文字幕| 免费成人在线观看| 日韩成人一级大片| 美女国产一区二区| 国产一区二区三区在线观看免费视频 | 中文字幕成人av| 国产精品久久久久久久久快鸭 | 亚洲国产精品黑人久久久| 中文字幕免费观看一区| 国产精品青草久久| 亚洲免费成人av| 无吗不卡中文字幕| 免费在线观看一区| 狠狠狠色丁香婷婷综合激情| 国产成人精品亚洲午夜麻豆| 成人性生交大片免费看中文| 不卡的av电影| 欧美日韩你懂的| 日韩欧美中文字幕制服| 精品88久久久久88久久久 | 日韩一区二区三区免费看 | 欧美日韩专区在线| 欧美一级理论性理论a| 精品国产成人在线影院| 中文字幕欧美激情一区| 亚洲一区在线视频观看| 蜜桃传媒麻豆第一区在线观看| 国产福利一区二区| 欧美在线看片a免费观看| 91精品国产高清一区二区三区| 久久久综合视频| 洋洋成人永久网站入口| 久久99在线观看| 一本一本大道香蕉久在线精品| 欧美日韩成人一区| 国产午夜亚洲精品羞羞网站| 亚洲一区二区三区三| 国产传媒久久文化传媒| 在线精品视频一区二区| 久久伊人中文字幕| 亚洲成人自拍网| 国产成人精品免费在线| 51午夜精品国产| 中文字幕av一区二区三区| 日韩激情视频网站| 99久久精品情趣| 日韩欧美在线影院| 亚洲黄色尤物视频| 国产乱子轮精品视频| 欧美日韩视频一区二区| 亚洲国产精品传媒在线观看| 国产乱人伦偷精品视频不卡| 91精彩视频在线| 久久久久9999亚洲精品| 亚洲成av人片在线| 97精品国产97久久久久久久久久久久| 欧美一区二区三区在线观看| 亚洲欧美日韩国产另类专区| 国产精品综合av一区二区国产馆| 在线播放欧美女士性生活| 亚洲欧洲三级电影| 国内精品免费**视频| 日韩视频免费观看高清完整版在线观看| 日韩美女久久久| 国产精品一区二区免费不卡| 日韩欧美资源站| 日韩国产精品久久久久久亚洲| 91麻豆国产在线观看| 欧美高清在线视频| 国产盗摄女厕一区二区三区| 日韩免费高清视频| 免费av成人在线| 欧美精品丝袜久久久中文字幕| 亚洲久草在线视频| 91麻豆自制传媒国产之光| 国产精品网站在线播放| 国产成人综合亚洲网站| 久久久青草青青国产亚洲免观| 日本中文字幕一区二区有限公司| 精品视频一区二区三区免费| 一区二区三区在线看| 色婷婷综合激情| 亚洲精品中文字幕乱码三区| 色婷婷久久久综合中文字幕 | 色天使色偷偷av一区二区|