婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > python基于concurrent模塊實(shí)現(xiàn)多線程

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

熱門標(biāo)簽:蘇州人工外呼系統(tǒng)軟件 打印谷歌地圖標(biāo)注 佛山通用400電話申請(qǐng) 淮安呼叫中心外呼系統(tǒng)如何 看懂地圖標(biāo)注方法 京華圖書(shū)館地圖標(biāo)注 電話機(jī)器人貸款詐騙 電話外呼系統(tǒng)招商代理 廣東旅游地圖標(biāo)注

引言      

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

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

操作多線程/多進(jìn)程

1、創(chuàng)建線程池

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

from concurrent import futures

pool = 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對(duì)象。可以看出此方法不會(huì)阻塞主線程的執(zhí)行。

import requests,datetime,time
from concurrent import futures

def 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  200
2021-03-12 15:29:10.923062:https://www.tmall.com  200
2021-03-12 15:29:10.940930:https://www.jd.com  200

3、map

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

  • fn:需要異步執(zhí)行的函數(shù)
  • *iterables:可迭代對(duì)象

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

import requests,datetime,time
from concurrent import futures



def 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  200
2021-03-12 16:14:05.033849:https://www.jd.com  200
2021-03-12 16:14:05.048952:https://www.tmall.com  200

4、wait

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

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

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


def 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  200
2021-03-12 16:30:13.552700:https://www.jd.com  200
2021-03-12 16:30:14.117325:https://www.tmall.com  200
2021-03-12 16:30:14.118284:主線程

5、異常處理

as_completed(fs, timeout=None)

  • 所有任務(wù) tasks

使用 concurrent.futures 操作 多線程/多進(jìn)程 過(guò)程中,很多函數(shù)報(bào)錯(cuò)并不會(huì)直接終止程序,而是什么都沒(méi)發(fā)生。使用 as_completed 可以捕獲異常,代碼如下

import requests,datetime,time
from concurrent import futures

def 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  200
None
2021-03-12 17:24:26.993939:https://www.jd.com  200
None
2021-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)多線程的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • python 實(shí)現(xiàn)多進(jìn)程日志輪轉(zhuǎn)ConcurrentLogHandler
  • Python并發(fā)concurrent.futures和asyncio實(shí)例
  • Python concurrent.futures模塊使用實(shí)例
  • python程序中的線程操作 concurrent模塊使用詳解
  • python concurrent.futures模塊的使用測(cè)試

標(biāo)簽:衡水 駐馬店 中山 呼和浩特 江蘇 畢節(jié) 股票 湖州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python基于concurrent模塊實(shí)現(xiàn)多線程》,本文關(guān)鍵詞  python,基于,concurrent,模塊,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python基于concurrent模塊實(shí)現(xiàn)多線程》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于python基于concurrent模塊實(shí)現(xiàn)多線程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲免费观看高清| 国产精品夜夜爽| 精品乱人伦一区二区三区| av午夜精品一区二区三区| 国产成人在线网站| 国产成人午夜精品影院观看视频| 国产一区二区三区久久久| 国产一区高清在线| 精品伊人久久久久7777人| 精品一区二区三区视频在线观看| 久久国内精品自在自线400部| 国产一区在线观看视频| 欧美性大战久久久久久久| 国产精品网站一区| 日本不卡中文字幕| 欧美日韩精品电影| 一区二区高清免费观看影视大全| 成人精品视频一区二区三区| 久久久.com| 国产精品白丝av| 国产精品亲子乱子伦xxxx裸| 国产宾馆实践打屁股91| 国产婷婷色一区二区三区四区| 亚洲人成小说网站色在线| 日本在线不卡视频| 成人午夜av电影| 精品国产百合女同互慰| 美腿丝袜亚洲综合| 91麻豆精品91久久久久久清纯| 国产精品久久三区| 99久久99久久精品国产片果冻| 国产婷婷色一区二区三区| 国产精品一二二区| 中文字幕av一区二区三区| 夫妻av一区二区| 亚洲男同性视频| 91精品蜜臀在线一区尤物| 日本免费新一区视频| 欧美一级夜夜爽| 国产999精品久久久久久| 国产精品家庭影院| 在线观看三级视频欧美| 午夜精品久久久久久久| 欧美丰满美乳xxx高潮www| 韩国理伦片一区二区三区在线播放| 欧美一级片在线观看| 国产91精品一区二区麻豆亚洲| 欧美激情中文字幕一区二区| 色综合久久久久久久久久久| 亚洲精品一区二区三区精华液| 亚洲人成影院在线观看| 久久久五月婷婷| 欧美三电影在线| 国产一区二区美女| 亚洲综合色噜噜狠狠| 国产色一区二区| 欧美精选在线播放| 91视频精品在这里| 成人综合婷婷国产精品久久蜜臀 | 67194成人在线观看| 蜜臀a∨国产成人精品| 国产精品超碰97尤物18| 日韩欧美亚洲一区二区| 99国产精品久久久久| 国产一区二区伦理片| 亚洲va欧美va国产va天堂影院| 久久精品网站免费观看| 欧美精品aⅴ在线视频| 成人短视频下载| 高清久久久久久| 成人ar影院免费观看视频| 国内成+人亚洲+欧美+综合在线| 综合网在线视频| 亚洲乱码国产乱码精品精的特点| 久久久久97国产精华液好用吗| 欧美日本国产视频| 91成人免费电影| 日韩亚洲欧美一区| 精品久久久三级丝袜| 国产欧美一区二区三区沐欲| 久久亚洲欧美国产精品乐播 | 国产精品护士白丝一区av| 日本一区二区成人| 久久久久久麻豆| 亚洲视频在线一区二区| 亚洲一区二区三区中文字幕| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲午夜精品久久久久久久久| 一个色综合av| 久久国产三级精品| 成人永久aaa| 欧美视频一二三区| 日韩一区二区三区视频| 久久久久久久久久久久久女国产乱| 国产精品色婷婷久久58| 亚洲一区二区3| 国产91在线看| 精品日韩在线观看| 亚洲女同女同女同女同女同69| 久久精品国产一区二区| 色综合天天综合| 色婷婷亚洲精品| 成人的网站免费观看| 欧美一区永久视频免费观看| 亚洲国产精品精华液ab| 日本va欧美va欧美va精品| 色综合久久66| 国产精品乱人伦中文| 国产黑丝在线一区二区三区| 欧美一区二区三区免费视频| 亚洲激情综合网| 成人av先锋影音| 国产精品女同一区二区三区| 国产一区二区三区在线观看免费| 91精品欧美一区二区三区综合在| 一区二区三区.www| 色久综合一二码| 亚洲国产视频a| 欧美日免费三级在线| 亚洲天天做日日做天天谢日日欢| 国产精品99久久久久久宅男| 国产欧美日韩一区二区三区在线观看| 琪琪久久久久日韩精品| 精品欧美黑人一区二区三区| 久久国产精品99久久久久久老狼| 久久嫩草精品久久久精品| 国产精品亚洲一区二区三区妖精| 久久视频一区二区| 5566中文字幕一区二区电影| 蜜臀av一区二区在线免费观看| 欧美sm极限捆绑bd| 国产麻豆精品视频| 亚洲欧美偷拍另类a∨色屁股| 欧美日韩在线直播| 麻豆一区二区三| 中文字幕在线不卡国产视频| 欧美顶级少妇做爰| 大白屁股一区二区视频| 亚洲午夜久久久久久久久电影网| 日韩免费福利电影在线观看| 91在线你懂得| 国产一区二区三区四区五区入口| 亚洲视频免费看| 精品国免费一区二区三区| 99视频精品在线| 日韩电影一区二区三区| 欧美一级xxx| 亚洲一区二区三区三| 韩国av一区二区三区在线观看| 欧美三级日韩在线| 欧美日韩视频专区在线播放| 国产亚洲欧美一区在线观看| 中文av一区特黄| 亚洲精品久久久蜜桃| 日产国产高清一区二区三区| 成人午夜精品在线| 一本色道久久综合亚洲aⅴ蜜桃 | 99久久精品99国产精品| 国产麻豆视频一区二区| 久草中文综合在线| 久久国产精品色婷婷| 国产高清视频一区| 成人av小说网| 欧美天堂一区二区三区| 91久久精品日日躁夜夜躁欧美| 成人激情校园春色| 99r国产精品| 精品视频一区二区三区免费| 欧美男同性恋视频网站| 久久久美女艺术照精彩视频福利播放| 国产欧美精品一区二区色综合| 一区二区在线免费观看| 男男视频亚洲欧美| 在线亚洲免费视频| 国产精品女同互慰在线看| 美女视频黄久久| 不卡区在线中文字幕| 欧美tickling网站挠脚心| 国产精品人妖ts系列视频| 成人激情开心网| 欧美激情在线观看视频免费| 奇米精品一区二区三区在线观看| 国产成人精品网址| 在线看不卡av| 亚洲激情图片小说视频| 国产成人免费在线视频| 久久久综合视频| 久久综合综合久久综合| 91精品国产高清一区二区三区| 亚洲女子a中天字幕| 国产成人在线视频免费播放| 欧美日韩亚洲综合在线 | 欧美麻豆精品久久久久久| 久久久久久久电影| 日韩精品亚洲一区二区三区免费| 福利一区福利二区| 国产色婷婷亚洲99精品小说| 久久av老司机精品网站导航| 欧美日韩国产片| 老司机一区二区|