问题引出
在看python多进程的时候,在网上看了很多教程,其中了解了解到GIL(全局解释器锁),有点困惑为什么有了这一大利器,还需要在多进程的时候去加锁?
什么是GIL
Python 全局解释器锁或GIL,简单来说,是一个互斥锁(或锁),它只允许一个线程控制 Python 解释器。
这意味着在任何时间点都只能有一个线程处于执行状态。执行单线程程序的开发人员看不到 GIL 的影响,但它可能是 CPU 密集型和多线程代码中的性能瓶颈。由于即使在具有多个 CPU 内核的多线程架构中,GIL 也只允许一次执行一个线程。
为何还需要锁呢
这其实是典型的多线程并发问题,python中很多操作并不是原子性的,python的GIL也只是针对与原子性操作的锁,比如一个数的累加操作,首先python的累加操作不是原子,共分三步,加载数据,累加计算,保存数据。 A线程执行这3步中,都有可能被切换走,执行B线程,这个时候就是锁的介入了。
# 一下操作是原子性的
L.append(x)
L1.extend(L2)
x = L[i]
x = L.pop()
L1[i:j] = L2
L.sort()
x = y
x.field = y
D[x] = y
D1.update(D2)
D.keys()
# 非原子性操作
i = i+1
L.append(L[-1])
L[i] = L[j]
D[x] = D[x] + 1