国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

python 實現多線程的三種方法總結

瀏覽:3日期:2022-06-21 13:24:04
1._thread.start_new_thread(了解)

import threadingimport timeimport _threaddef job(): print('這是一個需要執行的任務。。。。。') print('當前線程的個數:', threading.active_count() ) print('當前線程的信息:', threading.current_thread()) time.sleep(100)if __name__ == ’__main__’: # 創建多線程時, 需要制定該線程執行的任務 _thread.start_new_thread(job, ()) _thread.start_new_thread(job, ()) job()2.threading.Thread

import threadingimport timedef job(): print('這是一個需要執行的任務。。。。。') print('當前線程的個數:', threading.active_count() ) time.sleep(1) print('當前線程的信息:', threading.current_thread())if __name__ == ’__main__’: # 創建多線程時, 需要制定該線程執行的任務.name線程名字 target目標函數名 t1 = threading.Thread(target=job,name=’job1’) t2 = threading.Thread(target=job,name=’job2’) t1.start() t2.start() print(threading.active_count()) print('程序執行結束.....')

輸出:

這是一個需要執行的任務。。。。。

當前線程的個數: 3

這是一個需要執行的任務。。。。。

3

程序執行結束.....

當前線程的個數: 3

當前線程的信息: <Thread(job1, started 140416648140544)>

當前線程的信息: <Thread(job2, started 140416639747840)>

出現的問題: 主線程執行結束, 但是子線程還在運行。

join()方法可以等待所有的子線程執行結束之后, 再執行主線程。

import threadingimport timedef job(): print('這是一個需要執行的任務。。。。。') print('當前線程的個數:', threading.active_count() ) print('當前線程的信息:', threading.current_thread()) time.sleep(1)if __name__ == ’__main__’: # 創建多線程時, 需要制定該線程執行的任務.name線程名字 target目標函數名 t1 = threading.Thread(target=job,name=’job1’) t2 = threading.Thread(target=job,name=’job2’) t1.start() t2.start() print(threading.active_count()) # 出現的問題: 主線程執行結束, 但是子線程還在運行。 # 等待所有的子線程執行結束之后, 再執行主線程 t1.join() t2.join() print('程序執行結束.....')

python 實現多線程的三種方法總結

之前寫過一個簡單爬蟲的實驗,現在希望獲取十個ip的城市和國家

-不使用多線程

import timefrom urllib.request import urlopen# 記錄時間的裝飾器def timeit(f): def wrapper(*args, **kwargs):start_time = time.time()res = f(*args, **kwargs)end_time = time.time()print('%s函數運行時間:%.2f' % (f.__name__, end_time - start_time))return res return wrapperdef get_addr(ip): url = 'http://ip-api.com/json/%s' % (ip) urlObj = urlopen(url) # 服務端返回的頁面信息, 此處為字符串類型 pageContent = urlObj.read().decode(’utf-8’) # 2. 處理Json數據 import json # 解碼: 將json數據格式解碼為python可以識別的對象; dict_data = json.loads(pageContent) print('''%s 所在城市: %s 所在國家: %s''' % (ip, dict_data[’city’], dict_data[’country’]))@timeitdef main(): ips = [’12.13.14.%s’ % (i + 1) for i in range(10)] for ip in ips:get_addr(ip)if __name__ == ’__main__’: main()

python 實現多線程的三種方法總結

時間需要138.91秒。

-使用多線程

import threadingimport timefrom urllib.request import urlopendef timeit(f): def wrapper(*args, **kwargs):start_time = time.time()res = f(*args, **kwargs)end_time = time.time()print('%s函數運行時間:%.2f' % (f.__name__, end_time - start_time))return res return wrapperdef get_addr(ip): url = 'http://ip-api.com/json/%s' % (ip) urlObj = urlopen(url) # 服務端返回的頁面信息, 此處為字符串類型 pageContent = urlObj.read().decode(’utf-8’) # 2. 處理Json數據 import json # 解碼: 將json數據格式解碼為python可以識別的對象; dict_data = json.loads(pageContent) print('''%s 所在城市: %s 所在國家: %s''' % (ip, dict_data[’city’], dict_data[’country’]))@timeitdef main(): ips = [’12.13.14.%s’ % (i + 1) for i in range(10)] threads = [] for ip in ips:# 實例化10個對象,target=目標函數名,args=目標函數參數(元組格式)t = threading.Thread(target=get_addr, args=(ip, ))threads.append(t)t.start()# 等待所有子線程結束再運行主線程 [thread.join() for thread in threads]if __name__ == ’__main__’: main()

python 實現多線程的三種方法總結 python 實現多線程的三種方法總結

3.重寫run方法

重寫run方法, 實現多線程, 因為start方法執行時, 調用的是run方法;run方法里面編寫的內容就是你要執行的任務;

import threadingimport time# 重寫一個類,繼承于threading.Threadclass MyThread(threading.Thread): def __init__(self, jobName):super(MyThread, self).__init__()self.jobName = jobName # 重寫run方法, 實現多線程, 因為start方法執行時, 調用的是run方法; # run方法里面編寫的內容就是你要執行的任務; def run(self):print('這是一個需要執行的任務%s。。。。。' %(self.jobName))print('當前線程的個數:', threading.active_count() )time.sleep(1)print('當前線程的信息:', threading.current_thread())if __name__ == ’__main__’: t1 = MyThread('name1') t2 = MyThread('name2') t1.start() t2.start() t1.join() t2.join() print('程序執行結束.....')

重寫run方法實現剛才爬蟲多線程案例

import threadingimport timefrom urllib.request import urlopendef timeit(f): def wrapper(*args, **kwargs):start_time = time.time()res = f(*args, **kwargs)end_time = time.time()print('%s函數運行時間:%.2f' % (f.__name__, end_time - start_time))return res return wrapperclass MyThread(threading.Thread): def __init__(self, ip):super(MyThread, self).__init__()self.ip = ip def run(self):url = 'http://ip-api.com/json/%s' % (self.ip)urlObj = urlopen(url)# 服務端返回的頁面信息, 此處為字符串類型pageContent = urlObj.read().decode(’utf-8’)# 2. 處理Json數據import json# 解碼: 將json數據格式解碼為python可以識別的對象;dict_data = json.loads(pageContent)print(''' %s所在城市: %s所在國家: %s''' % (self.ip, dict_data[’city’], dict_data[’country’]))@timeitdef main(): ips = [’12.13.14.%s’ % (i + 1) for i in range(10)] threads = [] for ip in ips:# 實例化自己重寫的類t = MyThread(ip)threads.append(t)t.start() [thread.join() for thread in threads]if __name__ == ’__main__’: main()

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲综合区 | 91精品久久久久含羞草 | 欧美一级永久免费毛片在线 | 97国内免费久久久久久久久久 | 蕾丝视频永久在线入口香蕉 | 欧美黄色免费网站 | 九九在线精品视频播放 | 国产在线精品一区二区不卡 | 亚洲黄色三级网站 | 国产欧美日韩不卡在线播放在线 | 在线观看免费为成年视频 | 久久国产精品一国产精品 | 一级a俄罗斯毛片免费 | 俄罗斯毛片免费大全 | 亚洲国产最新在线一区二区 | 99在线观看视频免费 | 一级黄色α片 | 国产盗摄视频 | 欧美成人高清 | 91热久久免费频精品动漫99 | 制服丝袜在线视频香蕉 | 99久久免费国产香蕉麻豆 | 欧美在线视频 一区二区 | 亚洲国产欧美目韩成人综合 | 日韩一级片视频 | 欧美一级特黄刺激爽大片 | 视频在线观看一区 | 国产做爰一区二区 | 日韩天天摸天天澡天天爽视频 | 全免费a级毛片免费看 | 亚洲免费高清视频 | 久久不见久久见免费影院 | 亚洲欧美久久精品 | 一级毛片欧美大片 | 我要看欧美精品一级毛片 | 国产下药迷倒白嫩丰满美女j8 | 99国内精品 | 91亚洲免费| 日韩美女免费线视频 | 免费视频成人国产精品网站 | 亚洲欧美国产高清va在线播放 |