zoukankan      html  css  js  c++  java
  • 全局解释器锁(GIL)

    GIL本质就是一把互斥锁,既然是互斥锁,所有互斥锁的本质都一样,都是将并发运行变成串行,以此来控制同一时间内共享数据只能被一个任务所修改,进而保证数据安全。
     
    # 为何要有GIL?
        因为Cpython解释器自带垃圾回收机制不是线程安全的。
    # 如果不对垃圾回收机制线程做任何处理,也没有GIL锁行不行?
        提示:如果是问题的这种情况,多线程和垃圾回收线程就会并发了。
     
    Python代码的执行由Python虚拟机(也叫解释器循环)来控制。Python在设计之初就考虑到要在主循环中,同时只有一个线程在执行。
    虽然Python解释器中可以”运行“多个线程,但是任意时刻只有一个线程在解释器中运行。
    对Python虚拟机的访问由全局解释器锁(GIL)来控制,正是这个锁能保证同一时刻只有一个线程在运行。
    在多线程环境中,Python虚拟机按以下方式执行:
        1.设置 GIL;
        2.切换到一个线程去运行;
        3.运行指定数量的字节码指令或者线程主动让出控制(可以调用 time.sleep(0));
        4.把线程设置为睡眠状态;
        5.解锁 GIL;
        6.再次重复以上所有步骤。
    在调用外部代码(如C/C++扩展函数)的时候,GIL将会被锁定,直到这函数结束为止(由于在这种期间没有Python的字节码被运行,所以不会做线程切换)编写扩展的程序员可以主动解锁GIL。 
     
     
     
     
     
     
     
     
     
     
     
     
     

  • 相关阅读:
    Scrapy的安装和基本使用方法
    使用BERT词向量
    主动学习方法实践:让模型变“主动”
    WSAI2020
    mac电脑的图片存储的位置
    问答系统-不能直接根据问题寻找答案?
    谷歌飞马PEGASUS
    通过强化学习协作多代理对话模型训练
    学习笔记(55)- 深度学习工具及平台
    学习笔记(54)- NLU
  • 原文地址:https://www.cnblogs.com/sea-stream/p/14193314.html
Copyright © 2011-2022 走看看