日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
創(chuàng)新互聯(lián)Python教程:Python中的threading模塊是什么

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

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:主機(jī)域名、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、新津縣網(wǎng)站維護(hù)、網(wǎng)站推廣。

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

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

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

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

代碼如下:

#!/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ā)的操作,花費時間要短的很多。

二、threading.activeCount()的使用,此方法返回當(dāng)前進(jìn)程中線程的個數(shù)。返回的個數(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)前運行中的Thread對象列表。

相關(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è)置后臺進(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)成為后臺進(jìn)程。

threading.Thread

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

#coding=gbk
import threading, time, random
count = 0
class Counter(threading.Thread):
  def __init__(self, lock, threadName):
     
'''@summary: 初始化對象。
      
     
@param lock: 瑣對象。
     
@param threadName: 線程名稱。
     
'''
    super(Counter, self).__init__(name = threadName)
#注意:一定要顯式的調(diào)用父類的初始
化函數(shù)。
    self.lock = lock
    
  def run(self):
     
'''@summary: 重寫父類run方法,在線程啟動后執(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)建了一個Counter類,它繼承了threading.Thread。初始化函數(shù)接收兩個參數(shù),一個是鎖對象,另一個是線程的名稱。在Counter中,重寫了從父類繼承的run方法,run方法將一個全局變量逐一的增加10000。在接下來的代碼中,創(chuàng)建了五個Counter對象,分別調(diào)用其start方法。最后打印結(jié)果。這里要說明一下run方法 和start方法: 它們都是從Thread繼承而來的,run()方法將在線程開啟后執(zhí)行,可以把相關(guān)的邏輯寫到run方法中(通常把run方法稱為活動[Activity]。);start()方法用于啟動線程。


網(wǎng)站標(biāo)題:創(chuàng)新互聯(lián)Python教程:Python中的threading模塊是什么
文章起源:http://www.5511xx.com/article/dhjsgco.html