溫馨提示×

溫馨提示×

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

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

什么是Python中的threading模塊

發(fā)布時(shí)間:2020-08-25 16:16:31 來源:億速云 閱讀:247 作者:Leah 欄目:編程語言

什么是Python中的threading模塊?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

threading提供了一個(gè)比thread模塊更高層的API來提供線程的并發(fā)性。這些線程并發(fā)運(yùn)行并共享內(nèi)存。 

下面來看threading模塊的具體用法: 

一、Thread的使用,目標(biāo)函數(shù)可以實(shí)例化一個(gè)Thread對(duì)象,每個(gè)Thread對(duì)象代表著一個(gè)線程,可以通過start()方法,開始運(yùn)行。

這里對(duì)使用多線程并發(fā),和不適用多線程并發(fā)做了一個(gè)比較:

首先是不使用多線程的操作:

代碼如下:

#!/usr/bin/python
#compare for multi threads
import time
 
def worker():
    print "worker"
    time.sleep(1)
    return
 
if __name__ == "__main__":
    for i in xrange(5):
        worker()

執(zhí)行結(jié)果如下:

下面是使用多線程并發(fā)的操作:

代碼如下:

#!/usr/bin/python
import threading
import time
 
def worker():
    print "worker"
    time.sleep(1)
    return
 
for i in xrange(5):
    t = threading.Thread(target=worker)
    t.start()

可以明顯看出使用了多線程并發(fā)的操作,花費(fèi)時(shí)間要短的很多。

二、threading.activeCount()的使用,此方法返回當(dāng)前進(jìn)程中線程的個(gè)數(shù)。返回的個(gè)數(shù)中包含主線程。

代碼如下:

#!/usr/bin/python
#current's number of threads
import threading
import time
 
def worker():
    print "test"
    time.sleep(1)
 
for i in xrange(5):
    t = threading.Thread(target=worker)
    t.start()
 
print "current has %d threads" % (threading.activeCount() - 1)

三、threading.enumerate()的使用。此方法返回當(dāng)前運(yùn)行中的Thread對(duì)象列表。

相關(guān)推薦:《Python視頻教程》

代碼如下:

#!/usr/bin/python
#test the variable threading.enumerate()
import threading
import time
 
def worker():
    print "test"
    time.sleep(2)
 
threads = []
for i in xrange(5):
    t = threading.Thread(target=worker)
    threads.append(t)
    t.start()
 
for item in threading.enumerate():
    print item
 
print
 
for item in threads:
    print item

四、threading.setDaemon()的使用。設(shè)置后臺(tái)進(jìn)程。

代碼如下:

#!/usr/bin/python
#create a daemon
import threading
import time
 
def worker():
    time.sleep(3)
    print "worker"
 
t=threading.Thread(target=worker)
t.setDaemon(True)
t.start()
print "haha"

可以看出worker()方法中的打印操作并沒有顯示出來,說明已經(jīng)成為后臺(tái)進(jìn)程。

threading.Thread

Thread 是threading模塊中最重要的類之一,可以使用它來創(chuàng)建線程。有兩種方式來創(chuàng)建線程:一種是通過繼承Thread類,重寫它的run方法;另一種是創(chuàng)建一個(gè)threading.Thread對(duì)象,在它的初始化函數(shù)(__init__)中將可調(diào)用對(duì)象作為參數(shù)傳入。下面分別舉例說明。先來看看通過繼承threading.Thread類來創(chuàng)建線程的例子:

#coding=gbk
import threading, time, random
count = 0
class Counter(threading.Thread):
  def __init__(self, lock, threadName):
     
'''@summary: 初始化對(duì)象。
      
     
@param lock: 瑣對(duì)象。
     
@param threadName: 線程名稱。
     
'''
    super(Counter, self).__init__(name = threadName)
#注意:一定要顯式的調(diào)用父類的初始
化函數(shù)。
    self.lock = lock
    
  def run(self):
     
'''@summary: 重寫父類run方法,在線程啟動(dòng)后執(zhí)行該方法內(nèi)的代碼。
     
'''
    global count
    self.lock.acquire()
    for i in xrange(10000):
      count = count + 1
    self.lock.release()
lock = threading.Lock()
for i in range(5):
  Counter(lock, "thread-" + str(i)).start()
time.sleep(2) 
#確保線程都執(zhí)行完畢
print count

在代碼中,我們創(chuàng)建了一個(gè)Counter類,它繼承了threading.Thread。初始化函數(shù)接收兩個(gè)參數(shù),一個(gè)是鎖對(duì)象,另一個(gè)是線程的名稱。在Counter中,重寫了從父類繼承的run方法,run方法將一個(gè)全局變量逐一的增加10000。在接下來的代碼中,創(chuàng)建了五個(gè)Counter對(duì)象,分別調(diào)用其start方法。最后打印結(jié)果。這里要說明一下run方法 和start方法: 它們都是從Thread繼承而來的,run()方法將在線程開啟后執(zhí)行,可以把相關(guān)的邏輯寫到run方法中(通常把run方法稱為活動(dòng)[Activity]。);start()方法用于啟動(dòng)線程。


看完上述內(nèi)容,你們掌握什么是Python中的threading模塊的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

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

AI