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

    GIL应该是面试的一个常考题,什么是GIL?
      GIL的全程是Global Interpre Lock(全局解释器锁)。
    不是Python中有GIL,而是CPython中有全局解释器锁。(JPython中没有GIL)
    GIL是一个互斥锁,CPython在执行多线程的时候并不是线安全的,为了程序的安全性考虑了全局解释器锁。
     
    每个CPU在同一时间只能执行一个线程。
     
    在Python多线程下,每个线程的执行都需要进行锁的竞争,只有拿到GIL的线程才能执行。
    由于GIL的存在,python里一个进程永远只能同时执行一个线程,这就是为什么多核CPU上,python的多线程效率并不高。
     
    因为GIL的存在,python的多线程对CPU密集型代码并不友好,对IO密集性代码比较友好。
     
    1因为计算密集型的程序,需要占用系统资源。
    GIL的存在,相当于始终在进行单线程运算,速度慢。
    2.IO密集型影响不大的原因,IO,input/output,这两个词就表明程序的瓶颈在于输入
    所消耗的时间,线程大部分时间再等待,所以他们是多个一起等(多线程)还是单个等(单线程)无所谓

    多线程是共享内存的,即这些线程共用一个内存地址。好处在于便于线程间数据通信
    和数据同步
    多进程,各个进程地址之间是独立的内存地址。这样不存在地址之间通信就麻烦了
  • 相关阅读:
    实现IEnumberable接口和IEnumberator
    XAML-1
    Java基础00-Java概述1
    详解Lombok中的@Builder用法
    stream之map的用法
    stream之forEach的用法
    Java中map.getOrDefault()方法的使用
    BiPredicate的test()方法
    Function.identity()
    java 8 lamda Stream的Collectors.toMap 参数
  • 原文地址:https://www.cnblogs.com/materfont/p/9445936.html
Copyright © 2011-2022 走看看