濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Python 多線程之threading 模塊的使用

Python 多線程之threading 模塊的使用

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

簡(jiǎn)介

Python 通過(guò) _thread 和 threading 模塊提供了對(duì)多線程的支持,threading 模塊兼具了 _thread 模塊的現(xiàn)有功能,又?jǐn)U展了一些新的功能,具有十分豐富的線程操作功能

創(chuàng)建線程

使用 threading 模塊創(chuàng)建線程通常有兩種方式:

1)使用 threading 模塊中 Thread 類的構(gòu)造器創(chuàng)建線程,即直接對(duì)類 threading.Thread 進(jìn)行實(shí)例化,并調(diào)用實(shí)例化對(duì)象的 start 方法創(chuàng)建線程;

2)繼承 threading 模塊中的 Thread 類創(chuàng)建線程類,即用 threading.Thread 派生出一個(gè)新的子類,將新建類實(shí)例化,并調(diào)用其 start 方法創(chuàng)建線程。

構(gòu)造器方式

調(diào)用 threading.Thread 類的如下構(gòu)造器創(chuàng)建線程:

threading.Thread(group=None, target=None, name=None, args=(), kwargs={}, *, daemon=None)

group:指定該線程所屬的線程組,目前該參數(shù)還未實(shí)現(xiàn),為了日后擴(kuò)展 ThreadGroup 類實(shí)現(xiàn)而保留。
target:用于 run() 方法調(diào)用的可調(diào)用對(duì)象,默認(rèn)是 None,表示不需要調(diào)用任何方法。
args:是用于調(diào)用目標(biāo)函數(shù)的參數(shù)元組,默認(rèn)是 ()。
kwargs:是用于調(diào)用目標(biāo)函數(shù)的關(guān)鍵字參數(shù)字典,默認(rèn)是 {}。
daemon:如果 daemon 不是 None,線程將被顯式的設(shè)置為守護(hù)模式,不管該線程是否是守護(hù)模式,如果是 None (默認(rèn)值),線程將繼承當(dāng)前線程的守護(hù)模式屬性。
import time
import threading

def work(num):
    print('線程名稱:',threading.current_thread().getName(),'參數(shù):',num,'開始時(shí)間:',time.strftime('%Y-%m-%d %H:%M:%S'))

if __name__ == '__main__':
    print('主線程開始時(shí)間:',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('主線程結(jié)束時(shí)間:', time.strftime('%Y-%m-%d %H:%M:%S'))

上述示例中實(shí)例化了三個(gè) Thread 類的實(shí)例,并向任務(wù)函數(shù)傳遞不同的參數(shù),start 方法開啟線程,join 方法阻塞主線程,等待當(dāng)前線程運(yùn)行結(jié)束。

繼承方式

通過(guò)繼承的方式創(chuàng)建線程包括如下步驟:1)定義 Thread 類的子類,并重寫該類的 run 方法;2)創(chuàng)建 Thread 子類的實(shí)例,即創(chuàng)建線程對(duì)象;3)調(diào)用線程對(duì)象的 start 方法來(lái)啟動(dòng)線程。示例如下:

import time
import threading

class MyThread(threading.Thread):
    
    def __init__(self,num):
        super().__init__()
        self.num = num
    
    def run(self):
        print('線程名稱:', threading.current_thread().getName(), '參數(shù):', self.num, '開始時(shí)間:', time.strftime('%Y-%m-%d %H:%M:%S'))

if __name__ == '__main__':
   
     print('主線程開始時(shí)間:',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('主線程結(jié)束時(shí)間:', time.strftime('%Y-%m-%d %H:%M:%S'))

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

守護(hù)線程

守護(hù)線程(也稱后臺(tái)線程)是在后臺(tái)運(yùn)行的,它的任務(wù)是為其他線程提供服務(wù),如 Python 解釋器的垃圾回收線程就是守護(hù)線程。如果所有的前臺(tái)線程都死亡了,守護(hù)線程也會(huì)自動(dòng)死亡。來(lái)看個(gè)例子:

# 不設(shè)置守護(hù)線程
import threading

def work(num):
    for i in range(num):
        print(threading.current_thread().name + "  " + str(i))

t = threading.Thread(target=work, args=(10,), name='守護(hù)線程')
t.start()

for i in range(10):
    pass
# 設(shè)置守護(hù)線程
import threading

def work(num):
    for i in range(num):
        print(threading.current_thread().name + "  " + str(i))

t = threading.Thread(target=work, args=(10,), name='守護(hù)線程')
t.daemon = True
t.start()

for i in range(10):
    pass

上述示例直觀的說(shuō)明了當(dāng)前臺(tái)線程結(jié)束,守護(hù)線程也會(huì)自動(dòng)結(jié)束。

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

線程本地?cái)?shù)據(jù)

Python 的 threading 模塊提供了 local 方法,該方法返回得到一個(gè)全局對(duì)象,不同線程使用這個(gè)對(duì)象存儲(chǔ)的數(shù)據(jù),其它線程是不可見的(本質(zhì)上就是不同的線程使用這個(gè)對(duì)象時(shí)為其創(chuàng)建一個(gè)獨(dú)立的字典)。來(lái)看個(gè)示例:

# 不使用 threading.local
import threading
import time

num = 0

def work():
    global num
    
    for 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 是全局變量,變成了公共資源,通過(guò)輸出結(jié)果,我們發(fā)現(xiàn)子線程之間的計(jì)算結(jié)果出現(xiàn)了互相干擾的情況。

# 使用 threading.local
num = threading.local()

def work():
    num.x = 0
    
    for i in range(10):
        num.x += 1
    
    print(threading.current_thread().getName(), num.x)
    time.sleep(0.0001)

for i in range(5):
    threading.Thread(target=work).start()

使用 threading.local 的示例中,num 是全局變量,但每個(gè)線程定義的屬性 num.x 是各自線程獨(dú)有的,其它線程是不可見的,因此每個(gè)線程的計(jì)算結(jié)果未出現(xiàn)相互干擾的情況。

定時(shí)器

threading 模塊提供了 Timer 類實(shí)現(xiàn)定時(shí)器功能,來(lái)看個(gè)例子:

# 單次執(zhí)行
from threading import Timer

def work():
    print("Hello Python")
    
# 5 秒后執(zhí)行 work 方法
t = Timer(5, work)
t.start()

Timer 只能控制函數(shù)在指定的時(shí)間內(nèi)執(zhí)行一次,如果我們需要多次重復(fù)執(zhí)行,需要再進(jìn)行一次調(diào)度,想要取消調(diào)度時(shí)可以使用 Timer 的 cancel 方法。來(lái)看個(gè)例子:

# 重復(fù)執(zhí)行
count = 0

def work():
    print('當(dāng)前時(shí)間:', time.strftime('%Y-%m-%d %H:%M:%S'))
    global t, count
    count += 1
    # 如果 count 小于 5,開始下一次調(diào)度
    if count  5:
        t = Timer(1, work)
        t.start()

# 指定 2 秒后執(zhí)行 work 方法
t = Timer(2, work)
t.start()

以上就是Python 多線程之threading 模塊的使用的詳細(xì)內(nèi)容,更多關(guān)于python threading的使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Python中threading庫(kù)實(shí)現(xiàn)線程鎖與釋放鎖
  • Python多線程編程之threading模塊詳解
  • python中threading和queue庫(kù)實(shí)現(xiàn)多線程編程
  • Python threading模塊condition原理及運(yùn)行流程詳解
  • Python多線程threading創(chuàng)建及使用方法解析
  • Python3 socket即時(shí)通訊腳本實(shí)現(xiàn)代碼實(shí)例(threading多線程)
  • Python中使用threading.Event協(xié)調(diào)線程的運(yùn)行詳解
  • python繼承threading.Thread實(shí)現(xiàn)有返回值的子類實(shí)例
  • 淺談Python中threading join和setDaemon用法及區(qū)別說(shuō)明
  • python中threading開啟關(guān)閉線程操作
  • python threading模塊的使用指南

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python 多線程之threading 模塊的使用》,本文關(guān)鍵詞  Python,多,線程,之,threading,;如發(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 多線程之threading 模塊的使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python 多線程之threading 模塊的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    宁德市| 阿勒泰市| 达孜县| 金华市| 龙川县| 上饶县| 孝感市| 天等县| 固始县| 招远市| 和平县| 漳州市| 格尔木市| 岚皋县| 济宁市| 阿拉善右旗| 鹤庆县| 德兴市| 梁河县| 平陆县| 黄冈市| 宕昌县| 灵寿县| 集贤县| 稷山县| 蛟河市| 通州市| 绍兴县| 新余市| 金山区| 衡水市| 岚皋县| 合阳县| 紫金县| 射阳县| 松桃| 阿勒泰市| 萨迦县| 台中县| 吕梁市| 潼关县|