1.线程是应用程序的最小控制单元
import threading import time NUM = 10 def f(): global NUM NUM -= 1 time.sleep(2) print (NUM) for i in range(5): t = threading.Thread(target=f) t.start()
执行结果:
5 5 5 5 5
在这里,我们创建了5个线程,每个线程在程序还没有结束的时候就开始都对NUM进行了相应的操作,time.sleep(2)阻塞了进程的执行,造成进程的切换,所以在等待的2秒钟了,所有的线程都执行了-1的操作,最后都打印出来了最终的结果5.因为线程是共享一个进程中的资源,所以当线程之间的数据访问有交叉的时候,需要对线程进行加锁。
import threading import time NUM = 10 lock = threading.RLock() def f(): global NUM lock.acquire() NUM -= 1 time.sleep(2) lock.release() print (NUM) for i in range(5): t = threading.Thread(target=f) t.start()
执行结果:
9 8 7 6 5
加锁的方式有两种,一种是threading.Lock(),还有一种是threading.RLock(),后一种方式可以在锁里面嵌套锁,我们默认使用后面的方式比较多,兼容前面的Lock()锁。
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步