python web03-线程-10-使用互斥锁解决资源竞争的问题1
import threading
import time
# 定义一个全局变量
g_num = 0
def test1(num):
global g_num
# 上锁,如果之前没有被上锁,那么此时 上锁成功
# 如果上锁之前 已经被上锁了,那么此时会堵塞在这里,直到 这个锁被解开位置
mutex.acquire()
for i in range(num):
g_num += 1
# 解锁
mutex.release()
print("-----in test1 g_num=%d----" % g_num)
def test2(num):
global g_num
mutex.acquire()
for i in range(num):
g_num += 1
mutex.release()
print("-----in test2 g_num=%d=----" % g_num)
# 创建一个互斥锁,默认是没有上锁的
mutex = threading.Lock()
def main():
t1 = threading.Thread(target=test1, args=(1000000,))
t2 = threading.Thread(target=test2, args=(1000000,))
t1.start()
t2.start()
# 等待上面的2个线程执行完毕....
time.sleep(2)
print("-----in main Thread g_num = %d---" % g_num)
if __name__ == "__main__":
main()
注: mutex = threading.Lock() 通俗的来讲,就是 我在对某个东西操作的时候,任何人不能干预对这个东西的操作。如果其他人要操作,那么必须要让我先全部执行完以后,我发出通知,告诉其他排队的人,说我已经操作完了,其他人可以操作,否则都得排队。(可以简单理解为食堂排队,在一个不存在插队的食堂里面,第一个排队的人点菜完成以后,其他人才能点菜操作。)