一.引言
多线程是可以共享全局变量的,意味着多个线程可以同时操作一个全局变量,这很容易导致数据错误。
import threading
n = 0
def f():
global n $#函数内想使用全局变量要用global声明
for i in range(1000000):
n += 1
n -=1
print(n)
if __name__="__main__":
th1 = threading.Thread(target = f)
th2 = threading.Thread(target = f)
th1.start()
th2.start()
代码运行结果:
由上述代码可知由于线程1和线程2共同操作变量n,导致无法得到预期结果0(实际结果为1和2),所以让两个线程对一个变量同时操作是一件很危险的事情,从而就有了线程锁的存在
二.线程锁
作用:解决子线程共享全局变量时出现的数据冲突问题,从而确保数据的安全性和准确性
缺点:降低程序运行效率
使用步骤:
1.创建锁:lock = lock()
2.在编辑全局变量之前获取锁,锁定全局变量只能由子线程编辑:lock.acquire()
3.编辑完成后,释放锁:lock.release()
import threading,time
lock = threading.Lock() #创建锁
n = 0
def f():
global n #函数内想使用全局变量要用global声明
for i in range(1000000):
lock.acquire() #在编辑全局变量前获取锁
n += 1
n -=1
lock.release()
# 用with也可以上锁,并且它可以自动释放锁
#with lock:
# n +=1
# n _=1
print(n)
if __name__="__main__":
th1 = threading.Thread(target = f)
th2 = threading.Thread(target = f)
start = time.time()
th1.start()
th2.start()
th1.join()
th2.join()
print(time.time-start)
加了锁后两个子线程的结果都是0,而且运行时间变长了