Python多线程共享变量资源竞争问题
2022/1/24 14:04:38
本文主要是介绍Python多线程共享变量资源竞争问题,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1.资源竞争问题:sum+=1执行时大致会分为三步(取值、加1、写回),可能刚执行2步cpu就去切换到了另一个线程去执行; 2.解决办法:1.使用join()方法来设置线程同步(效率不高),2.加锁(可以保证同一时刻只有一个线程在执行)。
''' 资源竞争问题:sum+=1执行时大致会分为三步(取值、加1、写回),可能刚执行2步cpu就去切换到了另一个线程去执行 解决办法:1.使用join()方法来设置线程同步(效率不高),2.加锁(可以保证同一时刻只有一个线程在执行) ''' import threading import time sum=0 lock=threading.Lock() def add_num1(): global sum for i in range(1000000): # lock.acquire() # 加锁 sum+=1 # lock.release() # 解锁 print(f'{threading.current_thread().name}的计算结果是{sum}') def add_num2(): global sum for i in range(1000000): # lock.acquire() sum+=1 # lock.release() print(f'{threading.current_thread().name}的计算结果是{sum}') if __name__ == '__main__': t1=threading.Thread(target=add_num1) t2=threading.Thread(target=add_num2) t1.start() # 设置阻塞函数,设置线程同步 t1.join() t2.start() print(f'Main的sum值是{sum}')
这篇关于Python多线程共享变量资源竞争问题的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-08有遇到过吗?同样的规则 Excel 中 比Python 结果大
- 2024-03-30开始python成长之路
- 2024-03-29python optparse
- 2024-03-29python map 函数
- 2024-03-20invalid format specifier python
- 2024-03-18pool.map python
- 2024-03-18threads in python
- 2024-03-14python Ai 应用开发基础训练,字符串,字典,文件
- 2024-03-13id3 algorithm python
- 2024-03-13sum array elements python