溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python怎么實現(xiàn)多線程

發(fā)布時間:2021-04-26 10:19:51 來源:億速云 閱讀:154 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細講解有關(guān)python怎么實現(xiàn)多線程,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

Python的優(yōu)點有哪些

1、簡單易用,與C/C++、Java、C# 等傳統(tǒng)語言相比,Python對代碼格式的要求沒有那么嚴格;2、Python屬于開源的,所有人都可以看到源代碼,并且可以被移植在許多平臺上使用;3、Python面向?qū)ο?,能夠支持面向過程編程,也支持面向?qū)ο缶幊蹋?、Python是一種解釋性語言,Python寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序;5、Python功能強大,擁有的模塊眾多,基本能夠?qū)崿F(xiàn)所有的常見功能。

1._thread.start_new_thread(了解)

import threading
import time
import _thread
def job():
    print("這是一個需要執(zhí)行的任務(wù)。。。。。")
    print("當前線程的個數(shù):", threading.active_count() )
    print("當前線程的信息:", threading.current_thread())
    time.sleep(100)
if __name__ == '__main__':
    # 創(chuàng)建多線程時, 需要制定該線程執(zhí)行的任務(wù)
    _thread.start_new_thread(job, ())
    _thread.start_new_thread(job, ())
    job()

2.threading.Thread

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

輸出:

這是一個需要執(zhí)行的任務(wù)。。。。。

當前線程的個數(shù): 3

這是一個需要執(zhí)行的任務(wù)。。。。。

3

程序執(zhí)行結(jié)束.....

當前線程的個數(shù): 3

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

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

出現(xiàn)的問題: 主線程執(zhí)行結(jié)束, 但是子線程還在運行。

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

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

python怎么實現(xiàn)多線程

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

-不使用多線程

import time
from 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函數(shù)運行時間:%.2f" % (f.__name__, end_time - start_time))
        return res
    return wrapper
def get_addr(ip):
    url = "http://ip-api.com/json/%s" % (ip)
    urlObj = urlopen(url)
    # 服務(wù)端返回的頁面信息, 此處為字符串類型
    pageContent = urlObj.read().decode('utf-8')
    # 2. 處理Json數(shù)據(jù)
    import json
    # 解碼: 將json數(shù)據(jù)格式解碼為python可以識別的對象;
    dict_data = json.loads(pageContent)
    print("""
                        %s
    所在城市: %s
    所在國家: %s
    
    """ % (ip, dict_data['city'], dict_data['country']))
@timeit
def 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怎么實現(xiàn)多線程

時間需要138.91秒。

-使用多線程

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

python怎么實現(xiàn)多線程 python怎么實現(xiàn)多線程

3.重寫run方法

重寫run方法, 實現(xiàn)多線程, 因為start方法執(zhí)行時, 調(diào)用的是run方法;run方法里面編寫的內(nèi)容就是你要執(zhí)行的任務(wù);

import threading
import time
# 重寫一個類,繼承于threading.Thread
class MyThread(threading.Thread):
    def __init__(self, jobName):
        super(MyThread, self).__init__()
        self.jobName = jobName
    # 重寫run方法, 實現(xiàn)多線程, 因為start方法執(zhí)行時, 調(diào)用的是run方法;
    # run方法里面編寫的內(nèi)容就是你要執(zhí)行的任務(wù);
    def run(self):
        print("這是一個需要執(zhí)行的任務(wù)%s。。。。。" %(self.jobName))
        print("當前線程的個數(shù):", 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("程序執(zhí)行結(jié)束.....")

重寫run方法實現(xiàn)剛才爬蟲多線程案例

import threading
import time
from 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函數(shù)運行時間:%.2f" % (f.__name__, end_time - start_time))
        return res
    return wrapper
class 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)
        # 服務(wù)端返回的頁面信息, 此處為字符串類型
        pageContent = urlObj.read().decode('utf-8')
        # 2. 處理Json數(shù)據(jù)
        import json
        # 解碼: 將json數(shù)據(jù)格式解碼為python可以識別的對象;
        dict_data = json.loads(pageContent)
        print("""
                            %s
        所在城市: %s
        所在國家: %s
        
        """ % (self.ip, dict_data['city'], dict_data['country']))
@timeit
def 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()

關(guān)于“python怎么實現(xiàn)多線程”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI