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

    GIL全局解释器锁

    python解释器有很多种,最常见的就是CPython解释器

    GIL本质也是一把互斥锁:将并发变成串行牺牲效率保证数据的安全

    用来阻止用一进程地下的多线程的同时执行(同一进程内多个线程无法实现并行但是可以实现并发)

    GIL的存在是因为CPython解释器的内存管理不是线程安全的

    垃圾回收机制:引用计数,标记清除,分代回收

    研究python的多线程是否有用需要分情况谈论

    比如我们要开四个任务,都是计算密集型的,每个需要用时10s

    在单核情况下,开线程比开进程更节省资源

    在多核情况下,开进程比开线程更节省资源,比如开进程需要10s,而开线程需要40s。

    # 计算密集型 在多核情况下,开线程比开线程更节省时间资源
    from multiprocessing import Process
    from threading import Thread
    import os,time
    def work():
        res = 0
        for i in range(100000000):
            res *= i
    
    if __name__ == '__main__':
        l = []
        print(os.cpu_count())
        start = time.time()
        for i in range(4):
            p = Process(target=work)  # run time is 24.919609785079956
            # p = Thread(target=work)  # run time is 53.27436089515686
            l.append(p)
            p.start()
    
        for p in l:
            p.join()
            stop = time.time()
        print(f"run time is {stop-start}")
    
    # 计算IO密集型 在多核情况下,开线程要比开进程更节省时间资源
    from multiprocessing import Process
    from threading import Thread
    import threading
    import os,time
    def work():
        time.sleep(2)
    
    if __name__ == '__main__':
        l = []
        print(os.cpu_count())
        start = time.time()
        for i in range(40):
            # p = Process(target=work)  # run is 11.970486640930176
            p = Thread(target=work)  # run is 2.0098724365234375
            l.append(p)
            p.start()
    
        for p in l:
            p.join()
        stop = time.time()
        print(f'run is {stop-start}')
    

    Python的多线程到底有没有用,需要看情况而定,并且肯定是有用的。

    一般都是多进程+多线程配合使用。

    GIL与普通的互斥锁

    在多个资源抢占同一个资源时,有GIL锁的存在让同一个进程下的多个线程无法同时执行。即只有一个线程能够抢到锁,其他的要等到锁释放之后才可以抢,保证了数据的安全。

    from threading import Thread
    
    import time
    
    n = 100
    
    def task():
        global n
        tmp = n
        # time.sleep(1) # 0
        time.sleep(1)  # 在睡眠一秒后,只有一个线程抢到
        n = tmp - 1
    
    t_list = []
    for i in range(100):
        t = Thread(target=task)
        t.start()
        t_list.append(t)
    
    for t in t_list:
        t.join()
    
    print(n)  # 99
    
  • 相关阅读:
    Flask之flask-script
    Flask之flask-sqlalchemy
    sqlalchemy之基础操作
    Linux之服务管理
    python之PEP8规范
    app开发-1
    Mongodb之pymongo
    Mongodb之增删改查操作
    Mongodb之数据类型
    linux的virtualenv和virtualenvwarpper
  • 原文地址:https://www.cnblogs.com/zuihoudebieli/p/11385094.html
Copyright © 2011-2022 走看看