zoukankan      html  css  js  c++  java
  • Python GIL锁

    GIL全局解释器锁:为了解决多线程修改同一块数据。

      python的线程是调用操作系统的源生线程,启动时就是调用C语言的C源生接口,python调用C语言接口的线程去执行任务时,须上下文对应关系传给CPU处理。
     
    CPU处理python:
      通过上下文切换执行不同线程,一定是串行的。多核可以同时处理不同线程,在python中,不管有多少核,只能使用一核上下文切换执行。
     
    如图:
      当python开启4个线程同时处理一个数据时,如果本地的CPU是4核,在GIL不存在的情况下,4个线程会通过解释器,传给C口交给4个CPU单独管理,如果我的需求是让每个线程给num+1,它最终返回的结果是还是2,因为CPU会把数据copy给每个线程进行一次单独处理,数据并没有共享,所以这里,我们就用到了GIL锁,他会将每个线程串行处理,一个进程在处理时其他3个进程,等待第一个进程处理完成后在依次执行,因为是单独处理线程所以,用到的CPU只有一个,不管多少核CPU也只能使用一个处理,这也正是cpython不可解决的一个缺陷。
     
     
     
    总流程图:
  • 相关阅读:
    (7)排序之归并排序
    (5)排序之简单选择排序
    (4)排序之希尔排序
    (3)排序之直接插入排序
    (2)排序之快速排序
    (1)排序之冒泡排序
    Python学习
    centos下docker网络桥接
    docker下搭建gitlab
    centos版本7以上网卡名修改
  • 原文地址:https://www.cnblogs.com/xiangsikai/p/8178729.html
Copyright © 2011-2022 走看看