博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python进程和线程中的两个锁
阅读量:6988 次
发布时间:2019-06-27

本文共 680 字,大约阅读时间需要 2 分钟。

GIL锁(全局解释器锁)

gil锁的作用是:每个进程中同一时间只能有一个进程链接cpu,链接以后,cpu执行100个cpu指令以后,再由别的线程去链接cpu,

 

Rlock锁(可重入锁/递归锁)

 

import timeimport threadinglock = threading.RLock()n = 10def task(i):    print('这段代码不加锁',i)    # print('hello word')    lock.acquire() # 加锁,此区域的代码同一时刻只能有一个线程执行,并且只能是加锁的这个进程执行,cpu执行完100个cpu指令以后又返回来执行这个进程,直到进程执行完毕,再去调度别的进程    print('hello word')    global n    print('当前线程',i,'读取到的n值为:',n)    n = i    time.sleep(1)    print('当前线程',i,'修改n值为:',n)    lock.release() # 释放锁for i in range(10):    t = threading.Thread(target=task,args=(i,))    t.start()    #for循环循环的是准备好的一个线程实例,至于这个实例要运行多久,实例并不管他                 #start表示我已近准备好了,你可以调度我了

 

转载于:https://www.cnblogs.com/zhuhaofeng/p/9623381.html

你可能感兴趣的文章
使用xcopy进行日增量备份
查看>>
我的友情链接
查看>>
知之者不如好之者,好之者不如乐之者
查看>>
测试Application.Idle
查看>>
sizeof与strlen的区别与联系
查看>>
我的友情链接
查看>>
数组名取地址以及数组名作为sizeof操作符的操作数
查看>>
Citrix发布支持Framehawk技术的HDX协议,用户体验优势进一步扩大
查看>>
Android各种访问权限Permission详解
查看>>
asp.net 页面生命周期
查看>>
什么是钩子函数?
查看>>
Linux命令(基本)
查看>>
实战Active Directory站点部署与管理,Active Directory系列之十二
查看>>
信息和知识
查看>>
7.2 函数的参数
查看>>
Flex + Servlet 实现断点上传
查看>>
Linux学习笔记之用户登录
查看>>
【Linux】第二章系统设置及基本操作
查看>>
docker-compose ,docker-stack
查看>>
Myeclipse10安装设置配置Aptana插件
查看>>