久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

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

python threading模塊的使用指南

瀏覽:31日期:2022-06-17 14:02:20
目錄1. threding模塊創建線程對象2. threding模塊創建多線程3. 多線程的參數傳遞4. 線程產生的資源競爭1. threding模塊創建線程對象

接上述案例,我們可以利用程序阻塞的時間讓程序執行后面的任務,可以用多線程的方式去實現。對應的需要我們借助threading模塊去實現:如下所示

import timeimport threadingdef work():'''只有函數對象才能?煙錈?呋?''print(’5.洗茶杯: 1min ’ )time.sleep(1)print(’6.放茶葉: 1min ’ )time.sleep(1)start_time = time .time()print( ’1.洗壺: 1min ’ )time.s1eep(1)print( ’2.灌涼水:1min ’ )time.sleep(1)print( ’3.燒水: 1min ’ )time.sleep(1)print( ’4.等水燒開:3min ’ )work_thread = threading.Thread(target=work)# 啟動線程對象work_thread.start()time.sleep(1) # 5.洗茶杯: 1mintime.sleep(1) # 6.放茶葉: 1mintime.sleep(1)print( ’7.泡茶:1min ’ )time.sleep(1)print(’總共花了: ’,time.time() - start_time)

以上案例是一個單線程,需要特別注意的是threading模塊操作線程所操作的必須是函數對象。通過threding模塊可以把一個普通的函數對象轉化為線程對象。

2. threding模塊創建多線程

當一個進程啟動之后,會默認產生一個主線程,因為線程是程序執行流的最小單元,當設置多線程時,主線程會創建多個子線程,在python中,默認情況下,主線程執行完自己的任務以后,就退出了,此時子線程會繼續執行自己的任務,直到自己的任務結束。

import timeimport threadingdef upload():print('開始上傳文件...')time.sleep(2)print('完成上傳文件...')def down1oad():print('開始下載文件...')time.s1eep(2)print('完成下載文件...')if __name__ == ’__main__’:upload_thread = threading.Thread(target=up1oad)up1oad_thread .start()up1oad_thread.join()down1oad_thread = threading.Thread(target=down1oad,daemon=True)down1oad_thread.start()print(’主線程結束’)

也就是說主線程在分配任務時會創建多個子線程,子線程的任務進度不會阻礙主線程的執行。但是主線程會等待子線程執行任務完之后才結束主線程。也就是說實際上主線程是先執行完任務的,如果你想在主線程執行完之后就結束整個線程的話,那么可以設置守護主線程。

3. 多線程的參數傳遞

多線程的參數傳遞用args接受位置參數,用kwargs接受關鍵字參數。如下所示:

import threadingdef get(ur1,header=None): print(ur1) print(header)for url in [ ’https : / /www.baidu.com’, ’https:/ /www. soso.com ’ ,’ https: / /www . 360. com’]: # threading.Threadget_thread = threading. Thread(target=get,args=(ur1, ), kwargs={ ’ header ’:{ ’user-agent ’ : ’ pythonrequests’}}) get_thread.start4. 線程產生的資源競爭

首先我們來看一個案例:

import threadingimport timeimport randomdef add1(n): for i in range(100) :time.sleep(random.randint(1,3))with open( ’he7lo.txt’, mode=’a’, encoding=’utf-8 ’ ) as f: f.write(f’in} he1lo wor1d !’+ ’he7lo wor1d !’*1024) f.write(’ n ’)if __name__ == ’___main__’ : for n in range(10) :t1 = threading. Thread(target=add1,args=(n,))t1.start()

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

標簽: Python 編程
相關文章:
主站蜘蛛池模板: av免费网站在线观看 | 亚洲欧美精品 | 日韩网站免费观看 | 天天爽天天草 | 久久久国产精品 | 午夜成人免费电影 | 久久国内 | 国产精品视频专区 | 五月香婷婷| 91精品国产乱码久久久久久久久 | 日韩经典一区 | 成人免费激情视频 | 天天操天天添 | 91中文字幕在线观看 | 国产精品二区一区二区aⅴ污介绍 | 色综合久 | 91高清视频在线观看 | 国产视频综合在线 | 国内成人免费视频 | 波多野结衣精品 | 国产精品久久久久不卡 | av超碰在线 | 美女福利网站 | 伊人网站 | 中文字幕一区二区三区乱码图片 | 亚洲精品乱码久久久久久金桔影视 | 一级激情片 | 国产高清一区二区 | 毛片91| 国产婷婷精品av在线 | 国产精品69久久久久水密桃 | 欧美精品1区2区 | 99精品国产在热久久 | 国产成人精品免高潮在线观看 | 一区二区三区国产好 | 91高清视频在线观看 | 亚洲精品午夜aaa久久久 | 中文字幕日韩专区 | 国产婷婷色一区二区三区 | 精品成人免费一区二区在线播放 | 在线成人免费观看www |