线程
python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用
1. 使用threading模块
单线程执行
import threading import time def hello_for(): print("你好 世界, 你好 中国") time.sleep(1) if __name__ == "__main__": for i in range(5): t = threading.Thread(target=hello_for) t.start() #启动线程,即让线程开始执行
运行结果:
多线程执行
import threading import time def hello_for(): print("你好 世界, 你好 中国") time.sleep(1) if __name__ == "__main__": for i in range(5): t = threading.Thread(target=hello_for) t.start() #启动线程,即让线程开始执行
运行结果:
说明
- 可以明显看出使用了多线程并发的操作,花费时间要短很多
- 当调用
start()
时,才会真正的创建线程,并且开始执行
2. 主线程会等待所有的子线程结束后才结束
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() print(‘---结束---:%s‘%ctime())
运行结果:
3. 查看线程数量
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)
运行结果:
原文地址:https://www.cnblogs.com/aydenwang/p/9427862.html
时间: 2024-10-11 00:46:32