python GIL

来源:互联网 发布:淘宝囤货节在哪 编辑:程序博客网 时间:2024/06/06 06:40

一、GIL全称global interpreter lock,顾名思义,是一个全局的锁;

二、GIL是python解释器(CPython)所引入,不用CPython的解释器不受此限制;

三、GIL的存在会对多线程运行效率有很大影响,甚至比不过单线程运行效率;

    比如:当前有4核CPU,我们开了4个线程,每个线程被分配在4个核上。由于GIL的存在,同一时间点,只有一个线程获得锁,也就是说,4个核上,同一时间点只有一个线程在被执行。

    上述是对于CPU密集型运算的线程而言,当线程为IO密集型,情况可能会好一点,因为IO密集型线程在等待IO时,会释放GIL,从而提高部分效率。


四、GIL影响很大,修改很麻烦,因为有很多的模块都用了GIL;

五、如何避免?

利用multiprocess模块替代Thread,multiprocess是python的多进程模块,当多进程时,每个进程都有一个GIL,所以就不会有所得问题。

但是进程间共享数据会比较麻烦,编程时需要注意。


参考链接:http://python.jobbole.com/81822/