多線程-threading
python的thread模塊是比較底層的模塊,python的threading模塊是對(duì)thread做了一些包裝的,可以更加方便的被使用
1. 使用threading模塊
單線程執(zhí)行
#coding=utf-8
import time
def saySorry():
print("親愛的,我錯(cuò)了,我能吃飯了嗎?")
time.sleep(1)
if __name__ == "__main__":
for i in range(5):
saySorry()
多線程執(zhí)行
#coding=utf-8
import threading
import time
def saySorry():
print("親愛的,我錯(cuò)了,我能吃飯了嗎?")
time.sleep(1)
if __name__ == "__main__":
for i in range(5):
t = threading.Thread(target=saySorry)
t.start() #啟動(dòng)線程,即讓線程開始執(zhí)行
說明
- 可以明顯看出使用了多線程并發(fā)的操作,花費(fèi)時(shí)間要短很多
- 創(chuàng)建好的線程,需要調(diào)用
start()方法來啟動(dòng)
2. 主線程會(huì)等待所有的子線程結(jié)束后才結(jié)束
#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) # 屏蔽此行代碼,試試看,程序是否會(huì)立馬結(jié)束?
print('---結(jié)束---:%s'%ctime())

image.png
3. 查看線程數(shù)量
#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āng)前運(yùn)行的線程數(shù)為:%d'%length)
if length<=1:
break
sleep(0.5)

image.png