电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python基于concurrent模塊實現多線程

瀏覽:4日期:2022-06-22 10:27:08
引言

之前也寫過多線程的博客,用的是 threading ,今天來講下 python 的另外一個自帶庫 concurrent 。concurrent 是在 Python3.2 中引入的,只用幾行代碼就可以編寫出線程池/進程池,并且計算型任務效率和 mutiprocessing.pool 提供的 poll 和 ThreadPoll 相比不分伯仲,而且在 IO 型任務由于引入了 Future 的概念效率要高數倍。而 threading 的話還要自己維護相關的隊列防止死鎖,代碼的可讀性也會下降,相反 concurrent 提供的線程池卻非常的便捷,不用自己操心死鎖以及編寫線程池代碼,由于異步的概念 IO 型任務也更有優勢。

concurrent 的確很好用,主要提供了 ThreadPoolExecutor 和 ProcessPoolExecutor 。一個多線程,一個多進程。但 concurrent 本質上都是對 threading 和 mutiprocessing 的封裝。看它的源碼可以知道,所以最底層并沒有異步。ThreadPoolExecutor 自己提供了任務隊列,不需要自己寫了。而所謂的線程池,它只是簡單的比較當前的 threads 數量和定義的 max_workers 的大小,小于 max_workers 就允許任務創建線程執行任務。

操作多線程/多進程1、創建線程池

通過 ThreadPoolExecutor 類創建線程池對象,max_workers 設置最大運行線程數數。使用 ThreadPoolExecutor 的好處是不用擔心線程死鎖問題,讓多線程編程更簡潔。

from concurrent import futurespool = futures.ThreadPoolExecutor(max_workers = 2)2、submit

submit(self, fn, *args, **kwargs):

fn:需要異步執行的函數 *args,**kwargs:fn 接受的參數

該方法的作用就是提交一個可執行的回調task,它返回一個Future對象。可以看出此方法不會阻塞主線程的執行。

import requests,datetime,timefrom concurrent import futuresdef get_request(url): r = requests.get(url) print(’{}:{} {}’.format(datetime.datetime.now(),url,r.status_code))urls = [’https://www.baidu.com’,’https://www.tmall.com’,’https://www.jd.com’]pool = futures.ThreadPoolExecutor(max_workers = 2)for url in urls: task = pool.submit(get_request,url)print(’{}主線程’.format(datetime.datetime.now()))time.sleep(2)# 輸出結果2021-03-12 15:29:10.780141:主線程2021-03-12 15:29:10.865425:https://www.baidu.com 2002021-03-12 15:29:10.923062:https://www.tmall.com 2002021-03-12 15:29:10.940930:https://www.jd.com 2003、map

map(self, fn, *iterables, timeout=None, chunksize=1):

fn:需要異步執行的函數 *iterables:可迭代對象

map 第二個參數是可迭代對象,比如 list、tuple 等,寫法相對簡單。map 方法也不會阻塞主線程的執行。

import requests,datetime,timefrom concurrent import futuresdef get_request(url): r = requests.get(url) print(’{}:{} {}’.format(datetime.datetime.now(),url,r.status_code))urls = [’https://www.baidu.com’,’https://www.tmall.com’,’https://www.jd.com’]pool = futures.ThreadPoolExecutor(max_workers = 2)tasks = pool.map(get_request,urls)print(’{}:主線程’.format(datetime.datetime.now()))time.sleep(2)# 輸出結果2021-03-12 16:14:04.854452:主線程2021-03-12 16:14:04.938870:https://www.baidu.com 2002021-03-12 16:14:05.033849:https://www.jd.com 2002021-03-12 16:14:05.048952:https://www.tmall.com 2004、wait

如果要等待子線程執行完之后再執行主線程要怎么辦呢,可以通過 wait 。

wait(fs, timeout=None, return_when=ALL_COMPLETED):

fs:所有任務 tasks return_when:有三個參數 FIRST_COMPLETED:只要有一個子線程完成則返回結果。 FIRST_EXCEPTION:只要有一個子線程拋異常則返回結果,若沒有異常則等同于ALL_COMPLETED。 ALL_COMPLETED:默認參數,等待所有子線程完成。

import requests,datetime,timefrom concurrent import futuresdef get_request(url): r = requests.get(url) print(’{}:{} {}’.format(datetime.datetime.now(),url,r.status_code))urls = [’https://www.baidu.com’,’https://www.tmall.com’,’https://www.jd.com’]pool = futures.ThreadPoolExecutor(max_workers = 2)tasks =[]for url in urls: task = pool.submit(get_request,url) tasks.append(task)futures.wait(tasks)print(’{}:主線程’.format(datetime.datetime.now()))time.sleep(2)# 輸出結果2021-03-12 16:30:13.437042:https://www.baidu.com 2002021-03-12 16:30:13.552700:https://www.jd.com 2002021-03-12 16:30:14.117325:https://www.tmall.com 2002021-03-12 16:30:14.118284:主線程5、異常處理

as_completed(fs, timeout=None)

所有任務 tasks

使用 concurrent.futures 操作 多線程/多進程 過程中,很多函數報錯并不會直接終止程序,而是什么都沒發生。使用 as_completed 可以捕獲異常,代碼如下

import requests,datetime,timefrom concurrent import futuresdef get_request(url): r = requests.get(url) print(’{}:{} {}’.format(datetime.datetime.now(),url,r.status_code))urls = [’www.baidu.com’,’https://www.tmall.com’,’https://www.jd.com’]# 創建線程池pool = futures.ThreadPoolExecutor(max_workers = 2)tasks =[]for url in urls: task = pool.submit(get_request,url) tasks.append(task)# 異常捕獲 errors = futures.as_completed(tasks)for error in errors: # error.result() 等待子線程都完成,并拋出異常,中斷主線程 # 捕獲子線程異常,不會終止主線程繼續運行 print(error.exception())futures.wait(tasks)print(’{}:主線程’.format(datetime.datetime.now()))time.sleep(2)# 輸出結果Invalid URL ’www.baidu.com’: No schema supplied. Perhaps you meant http://www.baidu.com?2021-03-12 17:24:26.984933:https://www.tmall.com 200None2021-03-12 17:24:26.993939:https://www.jd.com 200None2021-03-12 17:24:26.994937:主線程

多進程編程也類似,將 ThreadPoolExecutor 替換成 ProcessPoolExecutor 。

以上就是python基于concurrent模塊實現多線程的詳細內容,更多關于python concurrent實現多線程的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 动力配电箱-不锈钢配电箱-高压开关柜-重庆宇轩机电设备有限公司 聚天冬氨酸,亚氨基二琥珀酸四钠,PASP,IDS - 远联化工 | 昊宇水工|河北昊宇水工机械工程有限公司 | 菏泽知彼网络科技有限公司| 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | 酒店品牌设计-酒店vi设计-酒店标识设计【国际级】VI策划公司 | 校车_校车价格_19座幼儿园校车_幼儿园校车_大鼻子校车 | 艺术漆十大品牌_艺术涂料加盟代理_蒙太奇艺术涂料厂家品牌|艺术漆|微水泥|硅藻泥|乳胶漆 | 塑料熔指仪-塑料熔融指数仪-熔体流动速率试验机-广东宏拓仪器科技有限公司 | 空气能采暖,热泵烘干机,空气源热水机组|设备|厂家,东莞高温热泵_正旭新能源 | 民用音响-拉杆音响-家用音响-ktv专用音响-万昌科技 | 玖容气动液压设备有限公司-气液增压缸_压力机_增压机_铆接机_增压器 | 东莞市超赞电子科技有限公司 全系列直插/贴片铝电解电容,电解电容,电容器 | 精密模具加工制造 - 富东懿| 会议会展活动拍摄_年会庆典演出跟拍_摄影摄像直播-艾木传媒 | 水上浮桥-游艇码头-浮动码头-游船码头-码瑞纳游艇码头工程 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 合肥白癜风医院_合肥治疗白癜风医院_合肥看白癜风医院哪家好_合肥华研白癜风医院 | 冷水机-工业冷水机-冷水机组-欧科隆品牌保障 | 槽钢冲孔机,槽钢三面冲,带钢冲孔机-山东兴田阳光智能装备股份有限公司 | 农业四情_农业气象站_田间小型气象站_智慧农业气象站-山东风途物联网 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 振动台-振动试验台-振动冲击台-广东剑乔试验设备有限公司 | 山东锐智科电检测仪器有限公司_超声波测厚仪,涂层测厚仪,里氏硬度计,电火花检漏仪,地下管线探测仪 | 福州甲醛检测-福建室内空气检测_环境检测_水质检测-福建中凯检测技术有限公司 | 手术室净化厂家_成都实验室装修公司_无尘车间施工单位_洁净室工程建设团队-四川华锐16年行业经验 | 干粉砂浆设备_干混砂浆生产线_腻子粉加工设备_石膏抹灰砂浆生产成套设备厂家_干粉混合设备_砂子烘干机--郑州铭将机械设备有限公司 | 天津仓储物流-天津电商云仓-天津云仓一件代发-博程云仓官网 | 耐火浇注料-喷涂料-浇注料生产厂家_郑州市元领耐火材料有限公司 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库-首页-东莞市傲马网络科技有限公司 | 酒糟烘干机-豆渣烘干机-薯渣烘干机-糟渣烘干设备厂家-焦作市真节能环保设备科技有限公司 | 济南货架定做_仓储货架生产厂_重型货架厂_仓库货架批发_济南启力仓储设备有限公司 | 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 磁力去毛刺机_去毛刺磁力抛光机_磁力光饰机_磁力滚抛机_精密金属零件去毛刺机厂家-冠古科技 | 电缆桥架生产厂家_槽式/梯式_热镀锌线槽_广东东莞雷正电气 | 加气混凝土砌块设备,轻质砖设备,蒸养砖设备,新型墙体设备-河南省杜甫机械制造有限公司 | 舞台木地板厂家_体育运动木地板_室内篮球馆木地板_实木运动地板厂家_欧氏篮球地板推荐 | 防火板_饰面耐火板价格、厂家_品牌认准格林雅 | 泰安办公家具-泰安派格办公用品有限公司| 济南玻璃安装_济南玻璃门_济南感应门_济南玻璃隔断_济南玻璃门维修_济南镜片安装_济南肯德基门_济南高隔间-济南凯轩鹏宇玻璃有限公司 |