在 Python 的原始解释器 CPython 中存在着 GIL(Global Interpreter Lock,全局解释器锁),因此在解释执行 Python 代码时,会产生互斥锁来限制线程对共享资源的访问,直到解释器遇到 I/O 操作或者操作次数达到一定数目时才会释放 GIL。 由于全局解释器锁的存在,在进行多线程操作的时候,不能调用多个 CPU 内核,只能利用一个内核,所以在进行 CPU 密集型操作的时候,不推荐使用多线程,更加倾向于多进程。 那么多线程适合什么样的应用场景呢?对于 IO 密集型操作,多线程可以明显提高效率,例如 Python 爬虫的开发,绝大多数时间爬虫是在等待 socket 返回数据,网络 IO 的操作延时比 CPU大 得多。