文章目录
什么是 GIL?
Python 虚拟机默认使用的是 CPython 解释器(C 语言实现),CPython 使用了 GIL (Golbal Iterpreter Lock - 全局解释器锁),来确保同一时间只有一个线程运行,所以即使再多的线程也只能有效的使用一个 CPU。
由于 GIL 的存在,即便是多线程的 Python 程序也无法利用多核 CPU 的优势。不过 I/O 密集型程序,依然适合使用多线程,因为它们大部分时间都在等待 I/O,对 CPU 依赖很低。
有了 GIL 还需要线程锁吗?
需要。GIL 只是解释器级别的锁,它能保证当多个线程在修改一个变量时不会崩溃,但结果可能是错乱的。 (虽然说Python有了GIL来锁住线程,但是并不意味着编写Python的程序的时候就不需要去注重线程安全了,因为有check_interval机制,还是会导致线程安全的问题。,因为有check_interval机制,还是会导致线程安全的问题)
如多个线程修改全部变量i = i + 1,是先读取 i,再加 1 后,最后写回内存,这会把在读与写期间其他线程对 i 的所有修改覆都盖掉。所以我们需要用线程锁来对整个读写过程加锁。
CPU 密集型 - 数学计算、搜索、图像处理等
I/O 密集型 - 文件操作、网络交互、数据库操作等。