线程同步

Posted wuheng-123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了线程同步相关的知识,希望对你有一定的参考价值。

大家都知道线程同步,是会资源强抢的,如果不在代码里加上锁,加以控制,结果就会出现非常的意外难以控制

#GIL(全局解释器锁)

#python中一个线程对应c语言中的-个线程

#gil使的同一时刻只有一个线程在一个cup上执行字节码,无法将多个线程映射到多个cpu上执行
#gil会根据执行的字节码行数以及时间片释放gil,io操作时会释放

# import dis
#
#
# def add(a):
# a = a+1
# return a
# print(dis.dis(add))#回归c语言
from threading import Lock,RLock#可重入的锁

#在同一个线程里面,可以连续调用多次acquire,一定要注意acquire的次数要和release的次数相等

total = 0
lock = Lock()


def add():
global total
# global lock
for i in range(100000):
lock.acquire()
total += 1
lock.release()


def desc():
global total
# global lock
for i in range(100000):
lock.acquire()
total -= 1
lock.release()

import threading

thread1 = threading.Thread(target=add)
thread2 = threading.Thread(target=desc)
thread1.start()
thread2.start()

thread1.join()
thread2.join()
print(total)

#1.用锁会影响性能
#2.锁会引起死锁





















































以上是关于线程同步的主要内容,如果未能解决你的问题,请参考以下文章

线程同步&线程池

线程同步

线程同步之读写锁

深入解析Python中的线程同步方法

同步-同步锁-死锁-线程交互-线程综合示例

多线程同步