day 34 进程线程排序 抢票 初级生产者消费者
# 实现的内容 模拟购票 20个人买,就有一张购票查,的时候大家都看到,但是购买只能一人购买成功
#利用互斥锁
# from multiprocessing import Process,Lock
# import os,random,json,time
# def search():
# with open('db.txt',encoding= 'utf-8')as f:
# dic = json.load(f) #反序列化 变成字典 因为文件里内容本身是字符串
# print('%s剩余的票数%s'%(os.getpid(),dic['count']))
# def get():
# with open('db.txt',encoding='utf-8')as read_f:
# dic = json.load(read_f)
# if dic['count']>0:
# dic['count']-=1
# time.sleep(random.randint(1,3))
# with open('db.txt','w',encoding='utf-8')as write_f:
# json.dump(dic,write_f) ##把字典写入文件 并且以字符串的形式
# print('%s抢票成功'% os.getpid())
#
# def task(mutex):
# search()
# mutex.acquire() # acquire 获得 互斥获得 加锁
# get()
# mutex.release() # 互斥释放 解锁
# if __name__=='__main__':
# mutex = Lock()
# for i in range(20):
# p = Process(target=task,args=(mutex,))
# p.start()
# #p.join() # 这个效果不能让其他人看见有票
##文件操作 文件的内容是默认存在的类型是字符串,而且里面用的json 必须是双引号。
# mutex 互斥
# mutex = Lock
# mutex.acquire() 加锁
# mutex.release 解锁 # db.txt
# {"count": 1}
# ----------线程的加锁的两种方法
# from threading import Thread,Lock
# import time
# n=100
#
# def task():
# # global n
# # mutex.acquire()
# # temp=n
# # time.sleep(0.1)
# # n=temp-1
# # mutex.release()
#
# global n
# with mutex:
# temp=n
# time.sleep(0.1)
# n=temp-1
# if __name__ == '__main__':
# mutex=Lock()
# t_l=[]
# for i in range(100):
# t=Thread(target=task)
# t_l.append(t)
# t.start()
# for t in t_l:
# t.join()
# print(n)
# ---------------
###生产者和消费者 初级供给 实现的并发
# from multiprocessing import Process,Queue
# import os,random,time
# def producer(q):
# for i in range(10):
# res = '包子%s'%i
# time.sleep(0.5)
# q.put(res)
# print('%s生产了%s'%(os.getpid(),res))
# ###time.sleep(random.randint(2,3)) #如果是启用此行 因为comsumer 的时间比较充裕比生产的
# ##供远远小于求 所以出现串行,生产出一个就立马吃一个
#
# def consumer(q):
# while True:
# res= q.get()
# if res is None:
# break
# print('%s吃了%s'%(os.getpid(),res))
# time.sleep(random.randint(2, 3))
# if __name__== '__main__':
# q = Queue()
# p = Process(target=producer,args=(q,))
# c = Process(target=consumer,args=(q,))
# p.start()
# c.start()
# p.join()
# q.put(None)
# print('主') import queue #线程队列 # # 队列 线程的排序
# q=queue.Queue(4)
# q.put({'a':1})
# q.put('xxxxx')
# q.put(3)
# q.put(4)
# print(q.get())
# print(q.get())
# print(q.get())
# print(q.get())
# 1进程的排序
# from multiprocessing import Queue
# q = Queue(3)
# q.put(3)
# q.put('wang')
# q.put({'wang':777})
# print(q.get())
# print(q.get())
# print(q.get())
# 3
# wang
# {'wang': 777}
# 进程引用序列 从前到后依次取值
# 变量=Queue(数字存几个)
# 变量.put(任意数据类型)
# 变量.get() 2#优先级队列 从小到大的排列
# q=queue.PriorityQueue(4)
# q.put((10,{'a':1}))
# q.put((-1,'xxxxx'))
# q.put((0,3))
# q.put((4,))
#
# print(q.get())
# print(q.get())
# print(q.get())
# print(q.get())
#
# (-1, 'xxxxx')
# (0, 3)
# (4,)
# (10, {'a}
# 3 堆栈 排序从后到前排序
# q=queue.LifoQueue(4)
# q.put({'a':1})
# q.put('xxxxx')
# q.put(3)
# q.put(4)
#
# print(q.get())
# print(q.get())
# print(q.get())
# print(q.get()) 进程 线程的顺序
守护进程:两个子进程,其中一个是守护子进程,一个主进程, 守护进程结束:是在主进程代码一结束就结束,
守护线程:两个子线程,其中一个是守护子线程,一个是主线程,守护线程结束:是在非守护子线程结束就结束。
day 34 进程线程排序 抢票 初级生产者消费者的更多相关文章
- 进程部分(IPC机制及生产者消费者模型)和线程部分
		
进程部分 一:进程间通信IPC机制:由于进程之间的内存空间是相互隔离的,所以为了进程间的通信需要一个共享的内存空间, 但是共享带来的问题是数据在写的时候就不安全了,所以需要一种机制既有能共享的内存 空 ...
 - 进程Queue、线程Queue、堆栈、生产者消费者模型
		
没学队列之前,可以用文件实现进程之间通信 但是有2个问题: 1. 速度慢:文件是保存在硬盘空间 2. 为了数据安全要加锁(处理锁是一件很麻烦的事,容易死锁,建议自己轻易不要处理锁) 队列:队列是基于管 ...
 - python并发编程之多进程(二):互斥锁(同步锁)&进程其他属性&进程间通信(queue)&生产者消费者模型
		
一,互斥锁,同步锁 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的, 竞争带来的结果就是错乱,如何控制,就是加锁处理 part1:多个进程共享同一打印终 ...
 - python开发进程:互斥锁(同步锁)&进程其他属性&进程间通信(queue)&生产者消费者模型
		
一,互斥锁,同步锁 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的, 竞争带来的结果就是错乱,如何控制,就是加锁处理 part1:多个进程共享同一打印终 ...
 - python网络编程--进程(方法和通信),锁, 队列,生产者消费者模型
		
1.进程 正在进行的一个过程或者说一个任务.负责执行任务的是cpu 进程(Process: 是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础.在 ...
 - 并发编程 - 进程 - 1.队列的使用/2.生产者消费者模型/3.JoinableQueue
		
1.队列的使用: 队列引用的前提: 多个进程对同一块共享数据的修改:要从硬盘读文件,慢,还要考虑上锁: 所以就出现了 队列 和 管道 都在内存中(快): 队列 = 管道 + 上锁 用队列的目的: 进程 ...
 - Linux进程通信之共享内存实现生产者/消费者模式
		
共享内存 共享内存是内核为进程创建的一个特殊内存段,它将出现在进程自己的地址空间中,其它进程可以将同一段共享内存连接(attach)到自己的地址空间.这是最快的进程间通信方式,但是不提供任何同步功能( ...
 - java 线程池、多线程实战(生产者消费者模型,1 vs 10) 附案例源码
		
导读 前二天写了一篇<Java 多线程并发编程>点我直达,放国庆,在家闲着没事,继续写剩下的东西,开干! 线程池 为什么要使用线程池 例如web服务器.数据库服务器.文件服务器或邮件服务器 ...
 - Linux下进程的同步相互排斥实例——生产者消费者
		
linux下的同步和相互排斥 Linux sync_mutex 看的更舒服点的版本号= = https://github.com/Svtter/MyBlog/blob/master/Linux/pth ...
 
随机推荐
- apiCloud 浏览图片
			
点击链接查看api详情 https://docs.apicloud.com/Client-API/Func-Ext/photoBrowser var photoBrowser = api.requir ...
 - bzoj2431
			
题意:求有多少个逆序对为k的排列 题解:\(dp[i][j]\)表示1~i的排列中有j个逆序对的方案数,转移就是把i放在1~i-1的排列中的第几位,\(dp[i][j]=\sum_{x=0}^{min ...
 - 合并CSV文件.bat
			
@echo off E:\保存文件夹 cd E:\文件所在的文件夹 dir copy *.csv all_keywords.csv echo @@@@@@@@@@@@@合并成功!@@@@@@@@@@@ ...
 - oracle错误整理
			
1. ORA-31640: unable to open dump file 解决:原来11g R2的IMPDP 增加了一个参数设置:CLUSTER,在设置了parallel参数>1的情况下, ...
 - Linux在shell中输入历史命令
			
在Linux的shell中,经常输入的命令有很多雷同,甚至是一样的, 如果是长命令,再次敲一遍效率真的是很低, 不过可以通过Ctl+r, 查找history中以前输入的命令,很是好用. 按Ctrl+ ...
 - java.sql.SQLException: Parameter index out of range (3 > number of parameters, which is 2).
			
java.sql.SQLException: Parameter index out of range (3 > number of parameters, which is 2). java. ...
 - JQuary中的FullPage属性的用法
			
$(document).ready(function(){ //常用方法 //$.fn.fullpage.moveSectionUp() //向上滚动一页 //$.fn.fullpage.m ...
 - JDK8的ConcurrentHashMap也会造成CPU 100%
			
转载:不止 JDK7 的 HashMap ,JDK8 的 ConcurrentHashMap 也会造成 CPU 100%?原因与解决~ 现象 大家可能都听过JDK7中的HashMap在多线程环境下可能 ...
 - Python学习之路【第一篇】-Python简介和基础入门
			
1.Python简介 1.1 Python是什么 相信混迹IT界的很多朋友都知道,Python是近年来最火的一个热点,没有之一.从性质上来讲它和我们熟知的C.java.php等没有什么本质的区别,也是 ...
 - 大量的QT控件及示例发放
			
QT属性控件项目https://github.com/lexxmark/QtnProperty 比特币交易软件https://github.com/JulyIGHOR/QtBitcoinTrader ...