# 管道
# 数据共享 Manager
# 进程池和回调函数 !
# !/usr/bin/env python
# !--*--coding:utf-8 --*--
# !@Time :2018/7/18 14:23
# !@Author TrueNewBee
# 管道 实现两进程间的信息传递
from multiprocessing import Pipe, Process # 一种使用管道方式
def func(conn3, conn4):
conn4.close() # 把多余通道关闭
while True:
try:
msg = conn3.recv() # 接收消息
print(msg)
except EOFError: # 没有数据可以取的时候抛出异常
conn3.close()
break if __name__ == '__main__':
conn1, conn2 = Pipe() # 接收两个参数 两个管道
Process(target=func, args=(conn1, conn2)).start()
conn1.close() # 关闭多余通道
for i in range(20):
conn2.send('吃了吗') # 发送消息
conn2.close()
# !/usr/bin/env python
# !--*--coding:utf-8 --*--
# !@Time :2018/7/18 15:01
# !@Author TrueNewBee # pipe 数据不安全性 这是一个例子,下面有另外一个解决方案的代码加上锁!
# IPC
import time
import random
from multiprocessing import Process, Pipe def producer(con1, pro1, name, food):
"""通过管道把生产东西传给消费者"""
con1.close()
for i in range(4):
time.sleep(random.randint(1, 3))
f = '%s生产%s%s' % (name, food, i)
print(f)
pro1.send(f)
pro1.close() def consumer(con2, pro2, name1):
pro2.close()
while True:
try:
food = con2.recv()
print('%s吃了%s' % (name1, food))
time.sleep(random.randint(1, 3))
except EOFError:
con2.close()
break if __name__ == '__main__':
con, pro = Pipe()
p = Process(target=producer, args=(con, pro, 'a', '泔水'))
c1 = Process(target=consumer, args=(con, pro, 'b'))
c2 = Process(target=consumer, args=(con, pro, 'c'))
c3 = Process(target=consumer, args=(con, pro, 'd'))
p.start()
c1.start()
c2.start()
c3.start()
con.close()
pro.close() # 加上锁解决pipe数据不安全问题
# from multiprocessing import Process, Pipe, Lock
#
#
# def consumer(p, name, lock1):
# produce1, consume1 = p
# produce1.close()
# while True:
# lock1.acquire()
# food=consume1.recv()
# lock.release()
# if food:
# print('%s 收到包子:%s' %(name,baozi))
# else:
# consume1.close()
# break
#
#
# def producer(p, n):
# produce2, consume2=p
# consume2.close()
# for i in range(n):
# produce2.send(i)
# produce2.send(None)
# produce2.send(None)
# produce2.close()
#
#
# if __name__ == '__main__':
# produce,consume=Pipe()
# lock = Lock()
# c1 = Process(target=consumer, args=((produce, consume), 'c1', lock))
# c2 = Process(target=consumer, args=((produce, consume), 'c2', lock))
# p1 = Process(target=producer, args=((produce, consume), 10))
# c1.start()
# c2.start()
# p1.start()
#
# produce.close()
# consume.close()
#
# c1.join()
# c2.join()
# p1.join()
# print('主进程') # 加锁来控制操作管道的行为 来避免进程之间争抢数据造成的数据不安全现象 # 队列 进程之间数据安全的
# 管道 + 锁
# !/usr/bin/env python
# !--*--coding:utf-8 --*--
# !@Time :2018/7/18 15:51
# !@Author TrueNewBee # 牺牲效率 保障了数据安全
from multiprocessing import Manager, Process, Lock def main(dic1, lock1):
lock1.acquire() # 加上所也是为了数据不安全问题
dic1['count'] -= 1
lock1.release() if __name__ == '__main__':
m = Manager()
lock = Lock()
dic = m.dict({'count': 100})
p_list = []
for i in range(50):
p = Process(target=main, args=(dic, lock))
p.start()
p_list.append(p)
for i in p_list:
p.join()
print('主进程:', dic)

管道介绍:

真正在用的时候,底层东西不用,都是拿来主义,面试造核弹,工作拧螺丝!!!

7.18 python进程间数据共享的更多相关文章

  1. 进程间数据共享 (multiprocess.Manager)

    进程间数据共享 (multiprocess.Manager) 一.进程之间的数据共享 展望未来,基于消息传递的并发编程是大势所趋 即便是使用线程,推荐做法也是将程序设计为大量独立的线程集合,通过消息队 ...

  2. python进程间共享数值、字典、列表变量

    ##python进程间共享数值.字典.列表变量 关注公众号"轻松学编程"了解更多. import multiprocessing def worker(num, mgr_dict, ...

  3. Perl进程间数据共享

    本文介绍的Perl进程间数据共享内容主体来自于<Pro Perl>的第21章. IPC简介 通过fork创建多个子进程时,进程间的数据共享是个大问题,要么建立一个进程间通信的通道,要么找到 ...

  4. Python程序中的进程操作-进程间数据共享(multiprocess.Manager)

    目录 一.进程之间的数据共享 1.1 Manager模块介绍 1.2 Manager例子 一.进程之间的数据共享 展望未来,基于消息传递的并发编程是大势所趋 即便是使用线程,推荐做法也是将程序设计为大 ...

  5. Python之路(第三十九篇)管道、进程间数据共享Manager

    一.管道 概念 管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信. 先画一幅图帮助大家理解下管道的基本原理 现有2个 ...

  6. python 进程间共享数据 (二)

    Python中进程间共享数据,除了基本的queue,pipe和value+array外,还提供了更高层次的封装.使用multiprocessing.Manager可以简单地使用这些高级接口. Mana ...

  7. 进程间数据传递:Queue,Pipe 进程间数据共享:Manager

    1.使用multiprocessing模块的Queue实现数据传递 ''' 进程间通讯: Queue,用法跟线程里的Queue一样,put,get 线程queue没有做序列化,进程queue做序列化了 ...

  8. Python 进程间数据交互

    进程间通信:进程之间必须需要中间件. 不同进程间内存是不共享的,要想实现两个进程间的数据交换     Queues:实现传输两个进程的数据 线程queue,访问数据只能在一个进程内进行线程与线程之间的 ...

  9. Python 进程间的通信

    #-*-coding:utf-8-*- '''python提供了多种进程间的通信方式,如:Queue,Pipe,Valie+Array等. Queue与Pipe的区别在于Pipe常用来在两个进程间通信 ...

随机推荐

  1. 运行jsp常犯的错误

    error 未启动tomcat服务 tomcat端口是否已改动 404: 未部署web应用 运行时URL输入错误 检查文件的存放位置(存放文件的目录无法对外引用,如WEB-INF , META-INF ...

  2. 关于测试中哪些信息需要放到jira上面

    1.每个新需求的功能点,全部在jira上一一呈现 2.每个bug也一样在jira上一一呈现 3.任务一个需要优化改进的点也一一在jira上呈现 然后程序员一直开发新功能和修改新bug,测试人员负责bu ...

  3. while 1要小心

    之前判断一个接口的返回,一定约定好了是返回retcode 1或者retcode 0,就用的这个判断,但是接口挂了的时候,一直返回未登录,找了很长时间为什么cpu一直消耗那么高. 使用wihle 1时候 ...

  4. Eclipse------启动Server时出现弹窗Server at localhost was unable to start within 45 seconds.

    弹窗详细信息: Server Tomcat v8. Server at localhost was unable to start within seconds. If the server requ ...

  5. Dubbo -- 系统学习 笔记 -- 示例 -- 泛化引用

    Dubbo -- 系统学习 笔记 -- 目录 示例 想完整的运行起来,请参见:快速启动,这里只列出各种场景的配置方式 泛化引用 泛接口调用方式主要用于客户端没有API接口及模型类元的情况,参数及返回值 ...

  6. VMWARE workstation 9 收缩虚拟硬盘

    在9以前的版本中可以通过在客户机中vmtools收缩硬盘,而在9以后这个功能没有了.虚拟机中使用过的虚拟硬盘即使删除了所有数据,使用vmware workstation 9 的clean up dis ...

  7. hive操作

    1.创建hive分区表: create table invites (id int, name string) partitioned by (ds string) row format delimi ...

  8. Spring中神奇@aotuWrited

    好久没有写博客了,放假就是充电学习的时候,的确一直是这样做的.来给自己一点掌声.我们还是进入今天的主题吧. 我们自己写代码一般会向下面这样干啊,因为这样简单,其余交给spring去做吧.Spring会 ...

  9. [JS] console.time() - 计时器构造函数及如何计时

    概述 使用计时器可以对代码运行过程进行测速.你可以给每个计时器取一个名字,每个页面上最多可以运行一万个计时器.当你使用计时器名字调用 console.timeEnd() 函数时,浏览器会返回一个毫秒值 ...

  10. 在linux下搭建ftp服务器【转】

    1 安装 vsftpd yum install vsftpd 2 配置 vsftpd 打开 vsftpd 文件: vi /etc/vsftpd/vsftpd.conf 初次修改前建议备份该文件 2.1 ...