>python的thread模塊是比較底層的模塊,python的threading模塊是對thread做了一些包裝的,可以更加方便的被使用
### 1. 使用threading模塊
單線程執行
~~~
#coding=utf-8
import time
def saySorry():
print("親愛的,我錯了,我能吃飯了嗎?")
time.sleep(1)
if __name__ == "__main__":
for i in range(5):
saySorry()
~~~
運行結果:

~~~
多線程執行
#coding=utf-8
import threading
import time
def saySorry():
print("親愛的,我錯了,我能吃飯了嗎?")
time.sleep(1)
if __name__ == "__main__":
for i in range(5):
t = threading.Thread(target=saySorry)
t.start() #啟動線程,即讓線程開始執行
~~~
運行結果:

說明
可以明顯看出使用了多線程并發的操作,花費時間要短很多
創建好的線程,需要調用start()方法來啟動
### 2. 主線程會等待所有的子線程結束后才結束
~~~
#coding=utf-8
import threading
from time import sleep,ctime
def sing():
for i in range(3):
print("正在唱歌...%d"%i)
sleep(1)
def dance():
for i in range(3):
print("正在跳舞...%d"%i)
sleep(1)
if __name__ == '__main__':
print('---開始---:%s'%ctime())
t1 = threading.Thread(target=sing)
t2 = threading.Thread(target=dance)
t1.start()
t2.start()
#sleep(5) # 屏蔽此行代碼,試試看,程序是否會立馬結束?
print('---結束---:%s'%ctime())
~~~

### 3. 查看線程數量
~~~
#coding=utf-8
import threading
from time import sleep,ctime
def sing():
for i in range(3):
print("正在唱歌...%d"%i)
sleep(1)
def dance():
for i in range(3):
print("正在跳舞...%d"%i)
sleep(1)
if __name__ == '__main__':
print('---開始---:%s'%ctime())
t1 = threading.Thread(target=sing)
t2 = threading.Thread(target=dance)
t1.start()
t2.start()
while True:
length = len(threading.enumerate())
print('當前運行的線程數為:%d'%length)
if length<=1:
break
sleep(0.5)
~~~