多線程-threading
python的thread模塊是比較底層的模塊瘩例,python的threading模塊是對thread做了一些包裝的啊胶,可以更加方便的被使用
1. 使用threading模塊
單線程執(zhí)行
#coding=utf-8
import time
def saySorry():
print("親愛的,我錯了垛贤,我能吃飯了嗎焰坪?")
time.sleep(1)
if __name__ == "__main__":
for i in range(5):
saySorry()
多線程執(zhí)行
#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() #啟動線程,即讓線程開始執(zhí)行
說明
- 可以明顯看出使用了多線程并發(fā)的操作部凑,花費時間要短很多
- 創(chuàng)建好的線程露乏,需要調用
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())
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('當前運行的線程數(shù)為:%d'%length)
if length<=1:
break
sleep(0.5)
image.png