python多线程共享变量的使用和效率方法

时间:2021-05-22

python多线程可以使任务得到并发执行,但是有时候在执行多次任务的时候,变量出现“意外”。

import threading,timen=0start=time.time()def b1(num): global n n=n+num n=n-numdef b2(num): for i in range(1000000): b1(num)t1=threading.Thread(target=b2,args=(5,))t2=threading.Thread(target=b2,args=(8,))t1.start()t2.start()t1.join()t2.join()end=time.time()print(n)print(end-start)

执行结果:

180.7520430088043213

可见变量n从0变成了18,用时是0.75s,原因是计算机系统计算类似n=n+num是分两步计算的,先计算n+num的值放进内存中,然后再把计算的值赋值给n,正是这个间隙导致了变量出现“意外”。

这时候可以使用threading.Lock来把线程中的变量锁定,使用完再释放!

import threading,timen=0lock=threading.Lock()start=time.time()def b1(num): global n n=n+num n=n-numdef b2(num): for i in range(1000000): lock.acquire()#等待获取或获取修改变量的权限,并霸占它们 b1(num) lock.release()#释放霸占的变量t1=threading.Thread(target=b2,args=(5,))t2=threading.Thread(target=b2,args=(8,))t1.start()t2.start()t1.join()t2.join()end=time.time()print(n)print(end-start)

执行结果:

03.335190773010254

虽然变量的值正确了,但慢了很多倍,效率大大的打折扣,多线程的优势也没凸显出来。

所以尽量使用局部变量来代替全局变量在线程中使用,这样可以避免效率的问题。

以上这篇python多线程共享变量的使用和效率方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章