为了解决多线程共享全局变量的问题。threading
提供了一个Lock
类,
这个类可以在某个线程访问某个变量的时候加锁,其他线程此时就不能进来
直到当前线程处理完后,把锁释放了,其他线程才能进来处理。
自己的理解: 锁机制就是严格控制(全局变量), 为了防止多线程同时执行某一条代码, 从而造成数据(一般是全局变量)
出错.把那条代码锁起来,一次只能一个线程执行.
import threading VALUE = 0 gLock = threading.Lock() # 创建一个锁 def add_value(): global VALUE # 全局变量在函数体中使用的时候,需要申明 gLock.acquire() # 加锁 for x in range(1000000): VALUE += 1 gLock.release() # 开锁 print('value: %d' % VALUE) def main(): for x in range(2): t = threading.Thread(target=add_value) t.start() if __name__ == '__main__': main()