GIL

在python的原始解释器CPython中存在着GIL(Global Interpreter Lock,全局解释器锁),因此在解释执行python代码时,会产生互斥锁来限制线程对资源的访问,直到解释器遇到I/O操作或者次数达到一定数目时才会释放GIL。所以,CPython的线程库直接封装了系统的原生线程,但CPython整体作为一个进程,同时只会有一个获得GIL的线程在运行,其他线程则处于等待状态。这就造成了即使在多核cpu中,多线程也只是做着分时切换而已。不过multiprocess的出现,已经可以让多进程的python代码编写简化到了类似多线程的程度

解决GIL:

1.能使用进程不用线程
2.高效的代码(多线程执行的任务)使用c,c++来编写

你可能感兴趣的:(GIL)