python进程同步(锁)(python 进程同步)
off999 2024-10-27 11:55 36 浏览 0 评论
进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的,
竞争带来的结果就是错乱,如何控制,就是加锁处理
举例
part1:多个进程共享同一打印终端
并发运行,效率高,但竞争同一打印终端,带来了打印错乱
#并发运行,效率高,但竞争同一打印终端,带来了打印错乱
from multiprocessing import Process
import os,time
def work():
print('%s is running' %os.getpid())
time.sleep(2)
print('%s is done' %os.getpid())
if __name__ == '__main__':
for i in range(3):
p=Process(target=work)
p.start()加锁:由并发变成了串行,牺牲了运行效率,但避免了竞争
#由并发变成了串行,牺牲了运行效率,但避免了竞争
from multiprocessing import Process,Lock
import os,time
def work(lock):
lock.acquire()
print('%s is running' %os.getpid())
time.sleep(2)
print('%s is done' %os.getpid())
lock.release()
if __name__ == '__main__':
lock=Lock()
for i in range(3):
p=Process(target=work,args=(lock,))
p.start()part2:多个进程共享同一文件
文件当数据库,模拟抢票
并发运行,效率高,但竞争写同一文件,数据写入错乱
#文件db的内容为:{"count":1}
#注意一定要用双引号,不然json无法识别
from multiprocessing import Process,Lock
import time,json,random
def search():
dic=json.load(open('db.txt'))
print('\033[43m剩余票数%s\033[0m' %dic['count'])
def get():
dic=json.load(open('db.txt'))
time.sleep(0.1) #模拟读数据的网络延迟
if dic['count'] >0:
dic['count']-=1
time.sleep(0.2) #模拟写数据的网络延迟
json.dump(dic,open('db.txt','w'))
print('\033[43m购票成功\033[0m')
def task(lock):
search()
get()
if __name__ == '__main__':
lock=Lock()
for i in range(100): #模拟并发100个客户端抢票
p=Process(target=task,args=(lock,))
p.start()加锁:购票行为由并发变成了串行,牺牲了运行效率,但保证了数据安全
#文件db的内容为:{"count":1}
#注意一定要用双引号,不然json无法识别
from multiprocessing import Process,Lock
import time,json,random
def search():
dic=json.load(open('db.txt'))
print('\033[43m剩余票数%s\033[0m' %dic['count'])
def get():
dic=json.load(open('db.txt'))
time.sleep(0.1) #模拟读数据的网络延迟
if dic['count'] >0:
dic['count']-=1
time.sleep(0.2) #模拟写数据的网络延迟
json.dump(dic,open('db.txt','w'))
print('\033[43m购票成功\033[0m')
def task(lock):
search()
lock.acquire()
get()
lock.release()
if __name__ == '__main__':
lock=Lock()
for i in range(100): #模拟并发100个客户端抢票
p=Process(target=task,args=(lock,))
p.start()总结:
加锁可以保证多个进程修改同一块数据时,同一时间只能有一个任务可以进行修改,即串行的修改,没错,速度是慢了,但牺牲了速度却保证了数据安全。
虽然可以用文件共享数据实现进程间通信,但问题是:
1.效率低
2.需要自己加锁处理
为此mutiprocessing模块为我们提供了基于消息的IPC通信机制:队列和管道。
1 队列和管道都是将数据存放于内存中
2 队列又是基于(管道+锁)实现的,可以让我们从复杂的锁问题中解脱出来,
我们应该尽量避免使用共享数据,尽可能使用消息传递和队列,避免处理复杂的同步和锁问题,而且在进程数目增多时,往往可以获得更好的可获展性。
相关推荐
- 一个手机号可以注册几个qq(一个手机号可以注册几个微信号)
-
可以注册多个QQ号方法如下:1、退出当前QQ,在登录界面点击“新用户注册”。2、输入本机的手机号码,点击下一步。3、输入手机接收到的验证码。4、点击“继续注册”。5、点击“不绑定”。6、输入新QQ昵称...
- 迷你世界官方版(迷你世界官方版官网入口)
-
我在官网上下载迷你世界的话,你需要进入浏览器网上下载APP进行下载迷你官网登录时候显示冻结可能是输密码错了好多几次导致的关于您的迷你世界账号被冻结了,可以添加官方联络方式或进行在线投诉建议等进行人...
- 浩辰cad看图王(浩辰cad看图王电脑版)
-
多。浩辰cad看图王相比于其他cad看图软件,拥有更多的功能可以使用。它不仅可以用来看图,还拥有图纸测量、添加标注、添加线条、文字等功能。解决方法如下:1、打开浩辰cad,输入一个命令,可以发现光标旁...
- 打字赚钱一单一结(打字赚钱一单一结app排行榜前十名)
-
以下是一些可以用于打字接单的App:1.蓝鲸输入法:这是一款功能强大的输入法工具,内置了打字接单功能,可以在输入法中直接接单并进行打字工作。2.有道云笔记:这是一款综合性笔记工具,在其中可以创建任...
-
- 免费自动连接wifi(最新万能钥匙安全免费自动连接)
-
大多数安卓手机都是支持自动连接免费wifi的。同时,为了安全起见,也有对应的选项:检查wifi安全性。这个可以开启的。当然如果只是经常使用常用地点的wifi,这个可以关闭。关闭方法以三星手机为例:进入“设置”,“连接”,“wlan”,“右上...
-
2026-02-01 02:43 off999
-
- 画图工具(画图工具在电脑哪里)
-
常用的绘图软件有以下这些:1、Coreldraw。Coreldraw是一个绘图和排版软件,主要处理矢量文件。主要用于商标设计、标志制作、模型绘制、插图绘制、排版、分色输出。它在艺术设计和商业设计领域非常流行。2、Photoshop。最强大...
-
2026-02-01 02:15 off999
- qq加速器(Bill bill加速器)
-
可能原因如下:1、官方服务器正在更新升级,为了给用户更好的体验,系统的维护是必不可少的。2、可以检查是否是网络出现了问题,可以更换网络是否正常。3、很多软件都在维护,包括QQ,微信,微博等,只能是等维...
- 进入qq安全中心的官网(qq安全中心入口)
-
1、以电脑版QQ为例,成功登录QQ后,点击界面左下角的“主菜单”图标;2、在弹出框里点击“安全”,再在右边的弹出框里点击“安全中心首页”;3、就会跳转到QQ安全中心的网页了,在里面进行修改密码、我的密...
- pp助手软件苹果版下载(pp助手苹果版免费下载)
-
工具:ipadmini41、打开ipad的桌面,点击safari浏览器进入。2、然后进入以后,在上面的搜索框里面,搜索z.25pp.com-pp助手,然后点击进入。3、然后进入以后就是安装pp助手的...
- 免费声卡软件下载(手机免费声卡软件下载)
-
应用商店上方下载。。第一步:打开浏览器,在网页中搜索“酷狗音乐播放器”,然后可以看到下面的页面。;第二步:选择第一个搜索结果(官网)中根据你要下载的类型切换电脑版、安卓版、苹果版,之后直接下载。;第三...
-
- qq游戏网页版在线登录(qq游戏网页版在线登录官网)
-
这个产品已经下线了啊扩展:WebQQ腾讯公司推出的使用网页方式上QQ的服务,特点是无需下载和安装QQ软件,只要能打开WebQQ的网站就可以登录QQ与好友保持联系。具有Web产品固有的便利性,同时在Web上最大限度的保持了客户端软件的操作习惯...
-
2026-02-01 01:03 off999
- 云电脑在线使用(云电脑怎样使用)
-
使用云电脑的步骤如下:1.注册:首先要有一个账号,然后登录云电脑的官网,进行注册,注册完成后,就可以正式使用云电脑了。2.安装:根据操作系统的不同,下载对应的云电脑客户端,安装完成后,登录账号,即可使...
- pp手机助手安卓版官网(pp手机助手官网首页)
-
你好,PP助手无法连接安卓手机可能出现以下情况:1.请确保手机与电脑连接的USB线正常,并选择正确的传输模式(如文件传输模式)。2.确保你的手机已经开启了USB调试模式。可以在手机设置中的开发者选...
- windows7安装版系统下载(win7安装版安装步骤)
-
1、win7系统装完后需要占用C盘空间10-15GB,如果把常用软件也安装到C盘,大小超过20+。 2、在分区的时候根据硬盘大小,如果硬盘相对较小,一般建议设置50G,最低不能低于30G。因...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
win7系统还原步骤图解(win7还原电脑系统的步骤)
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
16949认证费用是多少(16949审核员太难考了)
-
linux软件(linux软件图标)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
