当前位置:
首页 > temp > 简明python教程 >
-
python基础(32):进程(二)(4)
)
# print('%s正在和网红脸聊天' %self.person)
p1=Myprocess('哪吒')
p1.start()
print(p1.pid) #可以查看子进程的进程id
1.2 进程同步(multiprocess.Lock)
1.2.1 锁--multiprocess.Lock
通过刚刚的学习,我们千方百计实现了程序的异步,让多个任务可以同时在几个进程中并发处理,他们之间的运行没有顺序,一旦开启也不受我们控制。尽管并发编程让我们能更加充分的利用IO资源,但是也给我们带来了新的问题。
当多个进程使用同一份数据资源的时候,就会引发数据安全或顺序混乱问题。
多进程抢占输出资源:
- import os
- import time
- import random
- from multiprocessing import Process
- def work(n):
- print('%s: %s is running' %(n,os.getpid()))
- time.sleep(random.random())
- print('%s:%s is done' %(n,os.getpid()))
- if __name__ == '__main__':
- for i in range(3):
- p=Process(target=work,args=(i,))
- p.start()
使用锁维护执行顺序:
- # 由并发变成了串行,牺牲了运行效率,但避免了竞争
- import os
- import time
- import random
- from multiprocessing import Process,Lock
- def work(lock,n):
- lock.acquire()
- print('%s: %s is running' % (n, os.getpid()))
- time.sleep(random.random())
- print('%s: %s is done' % (n, os.getpid()))
- lock.release()
- if __name__ == '__main__':
- lock=Lock()
- for i in range(3):
- p=Process(target=work,args=(lock,i))
- p.start()
上面这种情况虽然使用加锁的形式实现了顺序的执行,但是程序又重新变成串行了,这样确实会浪费了时间,却保证了数据的安全。
接下来,我们以模拟抢票为例,来看看数据安全的重要性。
多进程同时抢购余票:
- #文件db的内容为:{"count":1}
- #注意一定要用双引号,不然json无法识别
- #并发运行,效率高,但竞争写同一文件,数据写入错乱
- from multiprocessing import Process,Lock
- import time,json,random
- def search():
- dic=json.load(open('db'))
- print('\033[43m剩余票数%s\033[0m' %dic['count'])
- def get():
- dic=json.load(open('db'))
- time.sleep(0.1) #模拟读数据的网络延迟
- if dic['count'] >0:
- dic['count']-=1
- time.sleep(0.2) #模拟写数据的网络延迟
- json.dump(dic,open('db','w'))
- print('\033[43m购票成功\033[0m')
- def task():
- search()
- get()
- if __name__ == '__main__':
- for i in range(100): #模拟并发100个客户端抢票
- p=Process(target=task)
- p.start()
使用锁来保证数据安全:
- #文件db的内容为:{"count":5}
- #注意一定要用双引号,不然json无法识别
- #并发运行,效率高,但竞争写同一文件,数据写入错乱
- from multiprocessing import Process,Lock
- import time,json,random
- def search():
- dic=json.load(open('db'))
- print('\033[43m剩余票数%s\033[0m' %dic['count
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数