美文网首页Python
互斥锁和Gil锁的关系

互斥锁和Gil锁的关系

作者: 楠木cral | 来源:发表于2023-02-20 09:50 被阅读0次

    Gil锁 : 保证同一时刻只有一个线程能使用到cpu

    互斥锁 : 多线程时,保证修改共享数据时有序的修改,不会产生数据修改混乱

    简单来说,GIL可以看做一个作用在cpu使用上的特殊互斥锁

    首先假设只有一个进程,这个进程中有两个线程 Thread1,Thread2, 要修改共享的数据date, 并且有互斥锁

    执行以下步骤

    (1)多线程运行,假设Thread1获得GIL可以使用cpu,这时Thread1获得 互斥锁lock,Thread1可以改date数据(但并
    没有开始修改数据)

    (2)Thread1线程在修改date数据前发生了 i/o操作 或者 ticks计数满100 (注意就是没有运行到修改data数据),这个
    时候 Thread1 让出了Gil,Gil锁可以被竞争

    (3) Thread1 和 Thread2 开始竞争 Gil (注意:如果Thread1是因为 i/o 阻塞 让出的Gil Thread2必定拿到Gil,如果
    Thread1是因为ticks计数满100让出Gil 这个时候 Thread1 和 Thread2 公平竞争)

    (4)假设 Thread2正好获得了GIL, 运行代码去修改共享数据date,由于Thread1有互斥锁lock,所以Thread2无法更改共享数据
    date,这时Thread2让出Gil锁 , GIL锁再次发生竞争

    (5)假设Thread1又抢到GIL,由于其有互斥锁Lock所以其可以继续修改共享数据data,当Thread1修改完数据释放互斥锁lock,
    Thread2在获得GIL与lock后才可对data进行修改

    ————————————————
    原文链接:https://blog.csdn.net/weixin_41594007/article/details/79485847

    相关文章

      网友评论

        本文标题:互斥锁和Gil锁的关系

        本文链接:https://www.haomeiwen.com/subject/pqzwkdtx.html