时间:2021-05-22
一、共享变量
共享变量:当多个线程访问同一个变量的时候。会产生共享变量的问题。
例子:
import threadingsum = 0loopSum = 1000000def myAdd(): global sum, loopSumfor i in range(1, loopSum): sum += 1def myMinu(): global sum, loopSumfor i in range(1, loopSum): sum -= 1if __name__ == "__main__": print("Dont,,,,,,,{0}".format(sum))t1 = threading.Thread(target = myAdd, args = ())t2 = threading.Thread(target = myMinu, args = ())t1.start()t2.start()t1.join()t2.join()print("Done,,,,,,{0}".format(sum))正如上面的结果可以看出:并不是我们期望的0,而是-286705,这就是因为我们共享变量了,同时对变量进行了操作,程序并不是原子的。
2.解决方案:使用“锁”,“信号灯”
(1)锁lock:是一个标志,表示一个线程在占用一些资源。
使用方式:先上锁,然后使用共享资源,放心的使用,最后再释放锁,即释放了这个变量。
锁哪个:哪个资源需要共享,那么就锁谁
import threadingsum = 0loopSum = 1000000lock = threading.Lock()# 先生成一个锁的实例def myAdd(): global sum, loopSumfor i in range(1, loopSum): lock.acquire()# 这里申请了一把锁sum += 1lock.release()# 注意千万不要忘了释放锁def myMinu(): global sum, loopSumfor i in range(1, loopSum): lock.acquire()sum -= 1lock.release()if __name__ == "__main__": print("Done,,,,,,,{0}".format(sum))t1 = threading.Thread(target = myAdd, args = ())t2 = threading.Thread(target = myMinu, args = ())t1.start()t2.start()t1.join()t2.join()print("Done,,,,,,{0}".format(sum))正如我们所预料的加减的顺序无所谓,但最后是零和游戏,但是上面的那个例子,都也是加减顺序无所谓,但是有一点要知道会存在同时对变量的内存使用的情况,这就存在内存被错写的风险,所以最后结果不对,上面的不是零和游戏。
(2)线程的安全问题:
如果一个资源、变量,他对于多线程来讲,不用加锁,也不会引起任何问题,则称为线程安全;线程不安全的变量类型:list\set\dict;线程安全的变量类型:queue
二、源码
d25_1_shared_variable_and_lock.py
https://github.com/ruigege66/Python_learning/blob/master/d25_1_shared_variable_and_lock.py
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一:概述项目中经常用遇到多线程操作共享数据问题,常用的处理方式是对共享数据进行加锁,如果多线程操作共享变量也同样采用这种方式。为什么要对共享变量加锁或使用原子操
最近被多线程给坑了下,没意识到类变量在多线程下是共享的,还有一个就是没意识到内存释放问题,导致越累越大1.python类变量在多线程情况下的是共享的2.pyth
那什么时候需要加锁呢,就是当多条线程同时操作一个变量时,就需要加锁了。上代码声明变量@interfaceViewController()@property(st
Python多进程默认不能共享全局变量主进程与子进程是并发执行的,进程之间默认是不能共享全局变量的(子进程不能改变主进程中全局变量的值)。如果要共享全局变量需要
python2.7在内存管理上相比python3还是有些坑的,其释放后的内存仍然保留在python的内存池中,不被系统所用。python循环引用的变量不会被回收