日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

python基于concurrent模塊實(shí)現(xiàn)多線程

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

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

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

操作多線程/多進(jìn)程1、創(chuàng)建線程池

通過 ThreadPoolExecutor 類創(chuàng)建線程池對象,max_workers 設(shè)置最大運(yùn)行線程數(shù)數(shù)。使用 ThreadPoolExecutor 的好處是不用擔(dān)心線程死鎖問題,讓多線程編程更簡潔。

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

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

fn:需要異步執(zhí)行的函數(shù) *args,**kwargs:fn 接受的參數(shù)

該方法的作用就是提交一個(gè)可執(zhí)行的回調(diào)task,它返回一個(gè)Future對象。可以看出此方法不會(huì)阻塞主線程的執(zhí)行。

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)# 輸出結(jié)果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:需要異步執(zhí)行的函數(shù) *iterables:可迭代對象

map 第二個(gè)參數(shù)是可迭代對象,比如 list、tuple 等,寫法相對簡單。map 方法也不會(huì)阻塞主線程的執(zhí)行。

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)# 輸出結(jié)果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

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

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

fs:所有任務(wù) tasks return_when:有三個(gè)參數(shù) FIRST_COMPLETED:只要有一個(gè)子線程完成則返回結(jié)果。 FIRST_EXCEPTION:只要有一個(gè)子線程拋異常則返回結(jié)果,若沒有異常則等同于ALL_COMPLETED。 ALL_COMPLETED:默認(rèn)參數(shù),等待所有子線程完成。

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)# 輸出結(jié)果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)

所有任務(wù) tasks

使用 concurrent.futures 操作 多線程/多進(jìn)程 過程中,很多函數(shù)報(bào)錯(cuò)并不會(huì)直接終止程序,而是什么都沒發(fā)生。使用 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’]# 創(chuàng)建線程池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() 等待子線程都完成,并拋出異常,中斷主線程 # 捕獲子線程異常,不會(huì)終止主線程繼續(xù)運(yùn)行 print(error.exception())futures.wait(tasks)print(’{}:主線程’.format(datetime.datetime.now()))time.sleep(2)# 輸出結(jié)果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:主線程

多進(jìn)程編程也類似,將 ThreadPoolExecutor 替換成 ProcessPoolExecutor 。

以上就是python基于concurrent模塊實(shí)現(xiàn)多線程的詳細(xì)內(nèi)容,更多關(guān)于python concurrent實(shí)現(xiàn)多線程的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久国产三级| 美女久久久久| 亚洲综合专区| 日本在线不卡视频一二三区| 亚洲人成网站在线在线观看| 日本麻豆一区二区三区视频| 久久国内精品视频| 久久中文字幕导航| 蜜桃视频在线网站| 一本大道色婷婷在线| 欧美成a人免费观看久久| 婷婷国产精品| 欧美精品一线| 中文字幕亚洲影视| 日韩av黄色在线| 你懂的国产精品永久在线| 91欧美在线| 国产精品美女久久久| 日韩精品高清不卡| 精品视频97| 尹人成人综合网| 日韩一区二区三区高清在线观看| 国产精品tv| 亚洲www啪成人一区二区| 久久不射中文字幕| 欧美日韩一区二区三区四区在线观看 | 欧美日韩一区自拍| 伊人网在线播放| 久久不射中文字幕| 国产精品乱战久久久| 日韩电影二区| 亚洲精一区二区三区| 国产精品1区在线| 久久久亚洲一区| 亚洲ab电影| 日韩欧美在线中字| 日韩精品一区二区三区免费视频 | 亚洲专区视频| 日本一区二区高清不卡| 亚洲欧美日韩国产一区| 久久99精品久久久久久园产越南 | 亚洲欧美日韩高清在线| 国产视频一区二区在线播放| 色婷婷精品视频| 91麻豆精品| 欧美高清一区| 大香伊人久久精品一区二区| 亚洲欧美日本日韩| 亚洲啊v在线| 青青草国产成人99久久| 欧美日韩第一| 精品国产一区二区三区av片| 亚洲涩涩av| 91精品婷婷色在线观看| 国产精品久久久久久妇女| 国内精品福利| 久久av日韩| 视频一区日韩| 日韩视频精品在线观看| 久久久久久婷| 久久精品99国产精品日本| 欧美精选一区二区三区| 欧美激情另类| 国产另类在线| 四虎精品永久免费| 免费日韩精品中文字幕视频在线| 国产在线观看www| 国产精品a级| 日韩1区2区3区| 丝袜a∨在线一区二区三区不卡| av资源中文在线天堂| 97精品久久| 亚洲欧洲日韩精品在线| 黄色日韩在线| 日本韩国欧美超级黄在线观看| 麻豆久久久久久| 97精品久久| 日韩av影院| 中文一区一区三区免费在线观| 久久五月天小说| 精品国产亚洲日本| 国产激情久久| 国产精品红桃| 欧美日韩亚洲国产精品| 亚洲最大av| 一区二区91| 国产亚洲精品v| 免播放器亚洲| 蜜臀精品久久久久久蜜臀| 亚洲女同中文字幕| 亚洲精品电影| 狠狠爱www人成狠狠爱综合网| 久久狠狠婷婷| 成人免费电影网址| 韩国三级一区| 久久久久国产精品一区三寸| 色偷偷偷在线视频播放| 色婷婷色综合| 黑森林国产精品av| 欧美日韩视频免费观看| 日韩精品一区二区三区免费观影| 国产黄大片在线观看| 久久久久久夜| 日本а中文在线天堂| 日韩免费av| 九九综合在线| 国产一区二区精品| 视频一区日韩| 久久国产精品美女| 四虎成人av| 影视先锋久久| 三级一区在线视频先锋| 日韩欧美精品一区二区综合视频| 日韩精品亚洲一区二区三区免费| 欧美日韩亚洲国产精品| 麻豆久久一区| 欧美激情国产在线| 亚洲精品中文字幕乱码| 亚州精品视频| 狠狠久久伊人| 免费国产自久久久久三四区久久 | 亚洲另类视频| 国产精品一区二区三区四区在线观看| 国产精品免费大片| 欧美国产偷国产精品三区| 欧美福利在线| 亚洲精品进入| 国产私拍福利精品视频二区| 高清一区二区| 伊人久久亚洲热| 久久精品xxxxx| zzzwww在线看片免费| 在线亚洲观看| 国产情侣久久| 亚洲午夜一级| 日韩av一区二区三区| 中文一区一区三区高中清不卡免费| 欧美91精品| 亚洲伊人影院| 中文在线免费视频| 日韩在线电影| 成人在线网站| 免费在线观看成人| 美女久久久久久| av一区二区高清| 国产精品伦一区二区| 欧美~级网站不卡| 国产欧美一区二区三区米奇| 日本美女一区| 欧美中文高清| 欧美精品一区二区三区精品| 国产日韩一区| 欧美日韩精品免费观看视频完整| 91p九色成人| 激情欧美丁香| 免费一区二区三区在线视频| 国产模特精品视频久久久久| 国产欧美日韩视频在线| 午夜精品婷婷| 国产成人久久精品一区二区三区| 国产精品普通话对白| 老司机精品在线| 日韩国产一区二| 欧美日韩国产精品一区二区亚洲| 国产亚洲人成a在线v网站| 亚洲婷婷免费| 国产精品二区不卡| 日本不卡高清| 不卡一区综合视频| 精品久久影院| 欧美日韩中文| 亚洲久久视频| www成人在线视频| 国产精品久一| 亚洲精品视频一二三区| 99久久久久国产精品| 欧美激情综合| 亚洲乱码久久| 国产偷自视频区视频一区二区| 天堂中文av在线资源库| 国产精品www.| 国产亚洲电影| 日韩国产高清在线| 先锋亚洲精品| 中文精品在线| 欧洲激情综合| 91精品啪在线观看国产18| 国产精品久久久免费| 午夜亚洲福利在线老司机| 999国产精品永久免费视频app| 国产探花一区在线观看| 亚洲va久久久噜噜噜久久| 中文在线不卡| 波多野结衣一区| 久久中文字幕二区| 久久精品欧美一区| 高清不卡亚洲| 都市激情国产精品| 久久久久久色 | 一区二区日韩免费看|