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

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

Python 多線程之threading 模塊的使用

瀏覽:192日期:2022-06-22 14:25:53
簡介

Python 通過 _thread 和 threading 模塊提供了對多線程的支持,threading 模塊兼具了 _thread 模塊的現有功能,又擴展了一些新的功能,具有十分豐富的線程操作功能

創建線程

使用 threading 模塊創建線程通常有兩種方式:

1)使用 threading 模塊中 Thread 類的構造器創建線程,即直接對類 threading.Thread 進行實例化,并調用實例化對象的 start 方法創建線程;

2)繼承 threading 模塊中的 Thread 類創建線程類,即用 threading.Thread 派生出一個新的子類,將新建類實例化,并調用其 start 方法創建線程。

構造器方式

調用 threading.Thread 類的如下構造器創建線程:

threading.Thread(group=None, target=None, name=None, args=(), kwargs={}, *, daemon=None)group:指定該線程所屬的線程組,目前該參數還未實現,為了日后擴展 ThreadGroup 類實現而保留。target:用于 run() 方法調用的可調用對象,默認是 None,表示不需要調用任何方法。args:是用于調用目標函數的參數元組,默認是 ()。kwargs:是用于調用目標函數的關鍵字參數字典,默認是 {}。daemon:如果 daemon 不是 None,線程將被顯式的設置為守護模式,不管該線程是否是守護模式,如果是 None (默認值),線程將繼承當前線程的守護模式屬性。

import timeimport threadingdef work(num): print(’線程名稱:’,threading.current_thread().getName(),’參數:’,num,’開始時間:’,time.strftime(’%Y-%m-%d %H:%M:%S’))if __name__ == ’__main__’: print(’主線程開始時間:’,time.strftime(’%Y-%m-%d %H:%M:%S’))t1 = threading.Thread(target=work,args=(3,)) t2 = threading.Thread(target=work,args=(2,)) t3 = threading.Thread(target=work,args=(1,))t1.start() t2.start() t3.start()t1.join() t2.join() t3.join()print(’主線程結束時間:’, time.strftime(’%Y-%m-%d %H:%M:%S’))

上述示例中實例化了三個 Thread 類的實例,并向任務函數傳遞不同的參數,start 方法開啟線程,join 方法阻塞主線程,等待當前線程運行結束。

繼承方式

通過繼承的方式創建線程包括如下步驟:1)定義 Thread 類的子類,并重寫該類的 run 方法;2)創建 Thread 子類的實例,即創建線程對象;3)調用線程對象的 start 方法來啟動線程。示例如下:

import timeimport threadingclass MyThread(threading.Thread):def __init__(self,num):super().__init__()self.num = numdef run(self):print(’線程名稱:’, threading.current_thread().getName(), ’參數:’, self.num, ’開始時間:’, time.strftime(’%Y-%m-%d %H:%M:%S’))if __name__ == ’__main__’:print(’主線程開始時間:’,time.strftime(’%Y-%m-%d %H:%M:%S’))t1 = MyThread(3) t2 = MyThread(2) t3 = MyThread(1)t1.start() t2.start() t3.start()t1.join() t2.join() t3.join()print(’主線程結束時間:’, time.strftime(’%Y-%m-%d %H:%M:%S’))

上述示例中自定義了線程類 MyThread,繼承了 threading.Thread,并重寫了 __init__ 方法和 run 方法。

守護線程

守護線程(也稱后臺線程)是在后臺運行的,它的任務是為其他線程提供服務,如 Python 解釋器的垃圾回收線程就是守護線程。如果所有的前臺線程都死亡了,守護線程也會自動死亡。來看個例子:

# 不設置守護線程import threadingdef work(num): for i in range(num):print(threading.current_thread().name + ' ' + str(i))t = threading.Thread(target=work, args=(10,), name=’守護線程’)t.start()for i in range(10): pass

# 設置守護線程import threadingdef work(num): for i in range(num):print(threading.current_thread().name + ' ' + str(i))t = threading.Thread(target=work, args=(10,), name=’守護線程’)t.daemon = Truet.start()for i in range(10): pass

上述示例直觀的說明了當前臺線程結束,守護線程也會自動結束。

如果你設置一個線程為守護線程,就表示這個線程是不重要的,在進程退出的時候,不用等待這個線程退出;如果你的主線程在退出的時候,不用等待哪些子線程完成,那就設置這些線程為守護線程;如果你想等待子線程完成后再退出,那就什么都不用做,或者顯示地將 daemon 屬性設置為 false。

線程本地數據

Python 的 threading 模塊提供了 local 方法,該方法返回得到一個全局對象,不同線程使用這個對象存儲的數據,其它線程是不可見的(本質上就是不同的線程使用這個對象時為其創建一個獨立的字典)。來看個示例:

# 不使用 threading.localimport threadingimport timenum = 0def work(): global numfor i in range(10):num += 1 print(threading.current_thread().getName(), num) time.sleep(0.0001) for i in range(5): threading.Thread(target=work).start()

上面示例中 num 是全局變量,變成了公共資源,通過輸出結果,我們發現子線程之間的計算結果出現了互相干擾的情況。

# 使用 threading.localnum = threading.local()def work(): num.x = 0for i in range(10):num.x += 1print(threading.current_thread().getName(), num.x) time.sleep(0.0001)for i in range(5): threading.Thread(target=work).start()

使用 threading.local 的示例中,num 是全局變量,但每個線程定義的屬性 num.x 是各自線程獨有的,其它線程是不可見的,因此每個線程的計算結果未出現相互干擾的情況。

定時器

threading 模塊提供了 Timer 類實現定時器功能,來看個例子:

# 單次執行from threading import Timerdef work(): print('Hello Python') # 5 秒后執行 work 方法t = Timer(5, work)t.start()

Timer 只能控制函數在指定的時間內執行一次,如果我們需要多次重復執行,需要再進行一次調度,想要取消調度時可以使用 Timer 的 cancel 方法。來看個例子:

# 重復執行count = 0def work(): print(’當前時間:’, time.strftime(’%Y-%m-%d %H:%M:%S’)) global t, count count += 1 # 如果 count 小于 5,開始下一次調度 if count < 5:t = Timer(1, work)t.start()# 指定 2 秒后執行 work 方法t = Timer(2, work)t.start()

以上就是Python 多線程之threading 模塊的使用的詳細內容,更多關于python threading的使用的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩精品2区| 午夜久久影院| 视频一区日韩| 国产欧美高清| 狠狠久久伊人| 久久国产亚洲| 国产精品88久久久久久| 首页国产欧美久久| 日本不卡视频一二三区| 久久精品72免费观看| 精品国产一区二区三区噜噜噜| 久久亚洲黄色| 精品国产免费人成网站| 日韩成人亚洲| 99亚洲精品| 欧美片网站免费| 国产精品成久久久久| 999视频精品| 亚洲啊v在线免费视频| 久久不卡日韩美女| 91精品国产成人观看| 日韩影院免费视频| 久久中文字幕一区二区三区| av在线日韩| 亚洲精品在线国产| 久久久久久久欧美精品| а√在线中文在线新版| 国产在线成人| 日韩一区免费| 水蜜桃久久夜色精品一区| 欧美日韩精品一本二本三本 | 涩涩av在线| 免费久久99精品国产| 欧美黄色精品| 亚洲激情社区| 国内精品伊人| 中文无码久久精品| www.com.cn成人| 欧美午夜三级| 亚洲女同中文字幕| 国产精品一区二区精品| 久久国产电影| 精品一区二区三区亚洲| 久久亚洲风情| 欧美日韩精品免费观看视完整| 日韩精品久久久久久| 少妇久久久久| 久久精品资源| 亚洲伊人影院| 久久亚洲成人| 成午夜精品一区二区三区软件| 亚洲视频国产精品| 久久一区二区三区喷水| 久久精品理论片| 亚洲精品第一| 精品91久久久久| 日韩一区二区中文| 国产精品视频3p| 亚洲精品九九| 亚洲精品电影| 久久国产主播| 人在线成免费视频| 久久久国产精品入口麻豆| 亚洲精品大全| 99riav1国产精品视频| 高清不卡亚洲| 国产精品久久久久久模特| 美女日韩在线中文字幕| 欧美亚洲国产激情| 亚洲电影有码| 另类专区亚洲| 福利一区视频| 久久精品国产网站| 国产欧美成人| 欧美日韩1区2区3区| 亚洲免费毛片| 一二三区精品| 视频在线在亚洲| 婷婷亚洲五月| 激情综合网址| 婷婷精品进入| 亚洲激精日韩激精欧美精品| 91九色精品| 亚洲资源av| 日韩专区一卡二卡| 日韩一级不卡| 老鸭窝毛片一区二区三区| 99在线观看免费视频精品观看| 婷婷丁香综合| 99riav1国产精品视频| 国产毛片久久| 亚洲精品乱码日韩| 日韩国产一二三区| 日本不卡视频在线观看| 日本伊人午夜精品| 欧美日韩xxxx| 国产精品**亚洲精品| 国产精品99精品一区二区三区∴| 国产精品大片| 精品免费av一区二区三区| 久久影视三级福利片| 精品亚洲精品| 一本大道色婷婷在线| 日韩精品免费一区二区三区| 亚洲不卡系列| 99国产精品视频免费观看一公开| 乱人伦精品视频在线观看| 免费在线观看成人| 日韩欧美中文在线观看| 国产精品一区二区三区美女 | 久久精品国产99国产| 国内精品美女在线观看| 99精品在线观看| 麻豆91精品| 日本不卡视频在线观看| 欧美国产另类| 欧洲精品一区二区三区| 亚洲一级影院| 亚洲欧洲av| 麻豆久久一区| 日韩毛片在线| 免费欧美在线视频| 免费在线播放第一区高清av| 中文一区一区三区高中清不卡免费| 99成人超碰| 日本vs亚洲vs韩国一区三区二区| 国产精品日韩精品在线播放| 日韩激情一区| 亚洲另类视频| 精品精品99| 亚洲激情不卡| 国产乱人伦丫前精品视频| 久久精品一区| 亚洲激情中文| 久久国产麻豆精品| 亚洲爱爱视频| 欧美亚洲福利| 亚洲大片在线| 清纯唯美亚洲综合一区| 蜜桃视频在线网站| 91福利精品在线观看| 色老板在线视频一区二区| 亚洲另类黄色| 日韩在线免费| 日韩精品视频一区二区三区| 国产精品专区免费| 日本不卡视频在线观看| 日韩成人免费| 亚洲香蕉视频| 久久精品影视| 久久国产日韩欧美精品| 美女毛片一区二区三区四区| 日本在线观看不卡视频| 久久精品一区二区不卡| 国产日韩一区| 国产精品婷婷| 韩国精品主播一区二区在线观看| 日本欧美大码aⅴ在线播放| 久久婷婷久久| 国产精品久久国产愉拍| 99riav国产精品| 日韩高清欧美| 国产欧美日韩免费观看| 欧美日韩激情| 伊伊综合在线| 国产精品久久久一区二区| 亚洲视频www| 电影亚洲精品噜噜在线观看| 国产欧美二区| 中文字幕日韩欧美精品高清在线| 91精品在线观看国产| 九九九精品视频| 日韩av一区二| 99日韩精品| 国产99精品一区| 国产一区二区三区视频在线| 日本精品另类| 伊人久久成人| 国产videos久久| 国产乱子精品一区二区在线观看 | av免费不卡国产观看| 国产情侣久久| 视频一区中文字幕精品 | 久久成人亚洲| 久久久久美女| 久久久久久自在自线| 91精品一区| 亚洲精品一级| 天堂va蜜桃一区二区三区| 九九久久婷婷| 播放一区二区| 日韩国产网站| 国产 日韩 欧美一区| 大香伊人久久精品一区二区| 美女视频一区在线观看| 欧美亚洲tv| 国产欧美视频在线| 日韩av黄色在线| 日韩avvvv在线播放| 日韩精品第二页|