原文鏈接:http://blog.sina.com.cn/s/blog_4b5039210100ewie.html
Thread對象中的一些方法:
以前說過多線程,用到threading模塊中的Thread對象,其中的start和run方法比較熟悉了,start()是重載了Thread對象中的run方法,其實作用還是,當執行這個start方法的時候,將運行run方法。
今天看看其他幾個重要的方法:
1 join方法,如果一個線程或者一個函數在執行過程中要調用另外一個線程,並且待到其完成以後才能接着執行,那麼在調用這個線程時可以使用被調用線程的join方法。
join([timeout])
裏面的參數時可選的,代表線程運行的最大時間,即如果超過這個時間,不管這個線程有沒有執行完畢,主線程或函數都會接着執行的。
看個例子:
>>> import threading
>>> import time
>>> class MyThread(threading.Thread):
def __init__(self,id):
threading.Thread.__init__(self)
self.id=id
def run(self):
x=0
time.sleep(20)
print self.id
>>> def func():
t.start()
for i in range(5):
print i
>>> t=MyThread(2)
>>> func()
0
1
2
3
4
>>> 2
可以看到,雖然在func裏面線程已經運行,但是函數並沒有等線程運行結束在執行,而是先把func執行完畢,打印0到4,然後等sleep(20),20秒結束後,這個MyThread(2),傳進去的2纔打印出。
>>> def func():
t.start()
t.join()
for i in range(5):
print i
>>> t=MyThread(3)
>>> func()
3
0
1
2
3
4
>>>
而這個呢,是當t.start()運行開始計時,20秒後,打印出id是3,然後func才接着運行,打印出0到4.
2. setDaemon()方法
這個方法基本和join是相反的。當我們在程序運行中,執行一個主線程,如果主線程又創建一個子線程,主線程和子線程就分兵兩路,分別運行,那麼當主線程完成想退出時,會檢驗子線程是否完成。如果子線程未完成,則主線程會等待子線程完成後再退出。但是有時候我們需要的是,只要主線程完成了,不管子線程是否完成,都要和主線程一起退出,這時就可以用setDaemon方法啦,
下面的例子就是設置子線程隨主線程的結束而結束:
import threading
import time
class myThread(threading.Thread):
def __init__(self,threadname):
threading.Thread.__init__(self,name=threadname)
def run(self):
time.sleep(5)
print self.getName()
def fun1():
t1.start()
print 'fun1 done'
def fun2():
t2.start()
print 'fun2 done'
t1=myThread('t1')
t2=myThread('t2')
t2.setDaemon(True)
fun1()
fun2()
上面這個例子,按照我們設想的輸出時:
fun1 done
fun2 done
t1
但是實際上我們在交互模式,主線程只有在python退出時終止,所以結果t2也是被打印出來啦。
3 .isAlive方法
當線程創建以後,可以使用Thread對象的isAlive方法查看線程是否運行。
>>> import threading
>>> import time
>>> class myThread(threading.Thread):
def __init__(self,id):
threading.Thread.__init__(self)
self.id=id
def run(self):
time.sleep(5)
print self.id
>>> t=myThread(1)
>>> def func():
t.start()
print t.isAlive()
>>> func()
True
>>> 1
4. 線程名
當線程創建後可以設置線程名來區分不同的線程,以便對線程進行控制。線程名可以在類的初始化函數中定義,也可以使用Thread對象的setName方法設置。下面是不同的方法來設置線程名。
>>> import threading
>>> class mythread(threading.Thread):
def __init__(self,threadname):
threading.Thread.__init__(self,name=threadname)
def run(self):
print self.getName()
>>>
>>> t1=mythread('t1')
>>> t1.getName()
't1'
>>> t1.setName('T')
>>> t1.getName()
'T'
>>> t2=mythread('t2')
>>> t2.start()
t2
>>>
>>> t2.getName()
't2'
>>> t2.setName('TT')
>>> t2.getName()
'TT'