一、全局解释器锁(Global Interpreter Lock,GIL)
1.什么是全局解释器锁
- 在同一个进程中只要有一个线程获取了全局解释器(cpu)的使用权限,那么其他的线程就必须等待该线程的全局解释器(cpu)使用权消失后才能使用全局解释器(cpu),即使多个线程直接不会相互影响在同一个进程下也只有一个线程使用cpu,这样的机制称为全局解释器锁(GIL)
- 是计算机程序设计语言解释器用于同步线程的一种机制,它使得任何时刻仅有一个线程在执行。即便在多核心处理器上,使用 GIL 的解释器也只允许同一时间执行一个线程。常见的使用 GIL 的解释器有CPython与Ruby MRI。来源:维基百科
2.全局解释器锁的好处
- 避免了大量的加锁解锁的好处
- 使数据更加安全,解决多线程间的数据完整性和状态同步
3.全局解释器锁的缺点
- 多核处理器退化成单核处理器,只能并发不能并行
(同一时刻的某个进程下的某个线程只能被一个cpu所处理,所以在GIL锁下的线程只能被并发,不能被并行。)
import time
import threading
def sub():
global num
num -= 1
time.sleep(1)
num = 100 # 定义一个全局变量
l = []
for i in range(100):
t = threading.Thread(target=sub) # 每次循环开启一个线程
t.start() # 开启线程
l.append(t)
for i in l:
i.join(