[python] GIL

发布时间:2019-08-25 09:35:04编辑:auto阅读(1241)

    http://www.dabeaz.com/python/UnderstandingGIL.pdf
    翻译水平不咋地,建议大家看原版英文,翻译只给自己参考,方便下次观看

    Python Threads

    A.python线程是真实的系统线程
    如1.POSIX threads (pthreads)
    2.Windows threads
    B.被主机操作系统全权管理
    C.代表python解释器进程的被执行线程

    什么是python GIL

    1.禁止并发执行
    2.包含全局解释器锁(GIL),GIL确保每次解释器只解释一个线程
    3.还有许多其他详情

    线程的运行机制

    [python] GIL
    1.在GIL下,多任务之间合作执行的方式如图所示
    2.在一个线程执行时,会保持GIL锁,切换线程时会释放GIL
    3.GIL锁类似于IO锁(send,recv,write,read)

    CPU限制任务

    [python] GIL
    1.CPU限制线程,不会通过执行IO限制,通过特殊方式
    2.使用CHECK方式每100"ticks"
    3.通过sys.setcheckinterval()改变CHECK的间隔
    ps:tick是python VM里的指令单元,与时间单位无关

    ps2:周期CHECK的内容:
    1.重置tick计数
    2.给主线程传送信号句柄
    3.释放GIL
    4.请求GIL
    5.原文给出了C代码来解释CHECK的方式,这里就不粘贴了

    后面的章节都是源码分析,就不翻译了,另外python3.2更新了GIL,不过并没有卵用,依然不能发挥多核优势,这篇文章主要介绍了python的GIL特性和原理,作为pyhton菜鸟学学就好,反正说多了我也不懂。

关键字

上一篇: python ftp

下一篇: python sched