python多進程使用及線程池的使用方法代碼詳解
更新時間:2018年10月24日 08:49:33 作者:火鳥網(wǎng)絡
這篇文章主要介紹了python多進程使用及線程池的使用方法代碼詳解,需要的朋友可以參考下
多進程:主要運行multiprocessing模塊
import os,time import sys from multiprocessing import Process class MyProcess(Process): """docstring for MyProcess""" def __init__(self, arg, callback): super(MyProcess, self).__init__() self.arg = arg self.callback = callback def run(self): self.callback(self.arg) def test(arg): print("子進程{}開始>>> pid={}".format(arg,os.getpid())) for i in range(1,5): sys.stdout.write("子進程{}運行中{}\r".format(arg,i)) sys.stdout.flush() time.sleep(1) def main(): print("主進程開始>>> pid={}".format(os.getpid())) myp=MyProcess(1,test) myp.start() myp2=MyProcess(2,test) myp2.start() myp.join() myp2.join() print("主進程終止") if __name__ == '__main__': main()
線程池:主要運用了未來模塊!下面例子,第一個是正常,第二第線程池,第三個用運行了2個線程池,會排隊
from concurrent.futures import ThreadPoolExecutor import time def sayhello(a): print("hello: "+a) time.sleep(2) def main(): seed=["a","b","c"] start1=time.time() for each in seed: sayhello(each) end1=time.time() print("time1: "+str(end1-start1)) start2=time.time() with ThreadPoolExecutor(3) as executor: for each in seed: executor.submit(sayhello,each) end2=time.time() print("time2: "+str(end2-start2)) start3=time.time() with ThreadPoolExecutor(2) as executor1: executor1.map(sayhello,seed) end3=time.time() print("time3: "+str(end3-start3)) if __name__ == '__main__': main()
總結
以上所述是小編給大家介紹的python多進程使用及線程池的使用方法代碼詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
使用python搭建代理IP池實現(xiàn)接口設置與整體調度
在網(wǎng)絡爬蟲中,代理IP池是一個非常重要的組件,由于許多網(wǎng)站對單個IP的請求有限制,因此,我們需要一個代理IP池,在本文中,我們將使用Python來構建一個代理IP池,然后,我們將使用這個代理IP池來訪問我們需要的數(shù)據(jù),文中有相關的代碼示例供大家參考,需要的朋友可以參考下2023-12-12Python機器學習iris數(shù)據(jù)集預處理和模型訓練方式
iris數(shù)據(jù)集包含150個樣本,每個樣本有4個特征及其類別信息,本文介紹了iris數(shù)據(jù)集的基本操作和如何使用knn模型進行花卉種類預測,是機器學習中的經(jīng)典案例,適用于監(jiān)督式學習2024-10-10django實現(xiàn)登錄時候輸入密碼錯誤5次鎖定用戶十分鐘
這篇文章主要介紹了django實現(xiàn)登錄時候輸入密碼錯誤5次鎖定用戶十分鐘,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11