三种进程和线程数据共享模块方法Queue》Pipe》manager
》》》》线程中的queue
import threading
import queue
def f(qq):
print("in child",qq.qsize())#打印父进程中q扥数据个数
qq.put([42,None,'hellow'])#往父进程中的q增减新的数据 if __name__ == '__main__':
q = queue.Queue()#父进程生成一个q
q.put('test123')#往父进程中增加数据
p = threading.Thread(target=f,args=(q,))#生成一个子线程,子线程执行函数f
p.start()#执行子线程
p.join()#等待子线程执行结束之后,父进程往下执行
print("444", q.get_nowait())#第一次取q中的数据
print("444", q.get_nowait())#第二次取q中的数据
1,父线程中生成一个q,子线程可以直接对q中的数据进行访问,访问完后父线程可以对子线程放入的数据进行操作,即数据实现了共享
》》》》》》》》进程中的queue
from multiprocessing import Process,Queue import threading
def f(qq):
print("in child",qq.qsize())
qq.put([42,None,'hellow']) if __name__ == '__main__':
q = Queue()#生成一个 q
q.put('test123')
p = Process(target= f,args=(q,))#生成一个线程,与主线程完全独立的内存地址,将q作为参数传递给函数f
p.start()
p.join()
print("444", q.get_nowait())
print("444", q.get_nowait())
1,区别线程中的queue和进程中的Queue的不同
》》》》》》》》》》》》》》》》Pipe
from multiprocessing import Process,Pipe def f(conn):
conn.send([42, None, 'hellow from child1'])
print("from parent", conn.recv())
conn.send([42, None, 'hellow from child2'])
print("from parent",conn.recv())
conn.close() if __name__ == "__main__":
parent_conn , child_conn = Pipe()
p = Process(target = f ,args= (child_conn,))
p.start()
print(parent_conn.recv())
parent_conn.send('我是主线程过来的1')
print(parent_conn.recv())
parent_conn.send('我是主线程过来的2')
p.join()
1,parent_conn , child_conn = Pipe()生成电话线两端的实例,相互接受
》》》》》》》》》》》》》manager
from multiprocessing import Process,Manager
import os
def f(d,l):#定义了一个字典和一个列表
d[(os.getpid())] = os.getpid()#当前线程的进程好加入到字典中
l.append(os.getpid())#当前进程的进程号加入到列表中
print(l)
if __name__ == '__main__':
# with Manager() as manager:
manager = Manager()#生成一个manager的实例
d = manager.dict()#生成一个字典可在多进程间共享和传递
l = manager.list(range(5))#生成一个列表可在多进程间共享和传递
p_list = []
for i in range(10):
p = Process(target=f,args=(d , l ))#生成带两个参数的进程
p.start()
p_list.append(p)
for result in p_list:
result.join()#等待结果
print(d)
print(l)
1,with Manager() as manager:
2. manager = Manager()#生成一个manager的实例
三种进程和线程数据共享模块方法Queue》Pipe》manager的更多相关文章
- Windows内核基础知识-8-监听进程、线程和模块
Windows内核基础知识-8-监听进程.线程和模块 Windows内核有一种强大的机制,可以在重大事件发送时得到通知,比如这里的进程.线程和模块加载通知. 本次采用链表+自动快速互斥体来实现内核的主 ...
- [转]SQL三种获取自增长的ID方法
最新更新请访问: http://denghejun.github.io SQL SERVER中的三种获得自增长ID的方法 这个功能比较常用,所以记下来以防自己忘掉. SCOPE_IDENTIT ...
- x64内核HOOK技术之拦截进程.拦截线程.拦截模块
x64内核HOOK技术之拦截进程.拦截线程.拦截模块 一丶为什么讲解HOOK技术. 在32系统下, 例如我们要HOOK SSDT表,那么直接讲CR0的内存保护属性去掉. 直接讲表的地址修改即可. 但是 ...
- 三种dedecms调用相关文章的方法
在文章的末尾或侧边栏添加相关文章可以提高用户的黏度,提高pv,增加se的好印象(哈哈),那么dedecms如何调用相关文章呢?有三种方法可以实现. 第一种dedecms调用相关文章的方法,用默认的li ...
- MySQL、SQLServer2000(及SQLServer2005)和ORCALE三种数据库实现分页查询的方法
在这里主要讲解一下MySQL.SQLServer2000(及SQLServer2005)和ORCALE三种数据库实现分页查询的方法. 可能会有人说这些网上都有,但我的主要目的是把这些知识通过我实际的应 ...
- 三种计算c#程序运行时间的方法
三种计算c#程序运行时间的方法 第一种: 利用 System.DateTime.Now // example1: System.DateTime.Now method DateTime dt1 = S ...
- 三种将list转换为map的方法(传统方法、jdk8 Stream流、guava)
三种将list转换为map的方法 - jackyrong - ITeye博客:http://jackyrong.iteye.com/blog/2158009
- 三、进程和线程、协程在python中的使用
三.进程和线程.协程在python中的使用 1.多进程一般使用multiprocessing库,来利用多核CPU,主要是用在CPU密集型的程序上,当然生产者消费者这种也可以使用.多进程的优势就是一个子 ...
- 多线程,线程类三种方式,线程调度,线程同步,死锁,线程间的通信,阻塞队列,wait和sleep区别?
重难点梳理 知识点梳理 学习目标 1.能够知道什么是进程什么是线程(进程和线程的概述,多进程和多线程的意义) 2.能够掌握线程常见API的使用 3.能够理解什么是线程安全问题 4.能够知道什么是锁 5 ...
随机推荐
- [转] 梦里Babel知多少(一)
平时开发中,经常需要用到ES6/ES7的语法.那么就需要用到Babel来对代码进行转码处理. 之前用Vue比较多,所以以Vue-cli作为参考来分析. 第一张图是几个月前的Vue-cli生成的 第二 ...
- cookie 详解
cookie概览 cookie是Web浏览器存储的少量命名数据,它与某个特定的网页或网站关联在一起.cookie是用来给Web浏览器提供内存,以便脚本和服务端程序可以在一个页面使用另一个页面的输入数据 ...
- 【Android】修改Android 模拟器IMSI
修改Android 模拟器IMEI 在.....\android_sdk\tools文件下找到emulator-arm.exe,使用UltraEdit文本编辑器打开,搜索CIMI关键字,把310260 ...
- 浅谈Rsync+Inotify实时同步
Rsync是Unix/Linux旗下的一款应用软件,利用它可以是多台服务器数据保持同步一致性,第一次同步时rsync会复制全部内容,但在下次只传输修改过的文件 Rsync在传输数据的过程中可以实行压缩 ...
- net core体系-web应用程序-4asp.net core2.0 项目实战(1)-3项目架构说明
本文目录1. 摘要2. 框架介绍 3. 权限管理之多一点说明4. 总结 1. 摘要 NCMVC角色权限管理框架是由最近练习Net Core时抽时间整理的系统,后续能不能发展成一个cms还要看朋友们是 ...
- detailFormatter bootstrapTable
detailView : true,//会导致表格最开头多出一列 detailFormatter :function(index, row, element){ var image = '<di ...
- 使用EndNote在Word中插入参考文献
以百度文库为例,首先找到我们要插入的参考文献,比如 搜索关键词,然后下需要的论文下面点击引用 得到 点击下面导出链接的EndNote,会下载一个.enw文件 找到此文件并双击打开后即已经导入到EndN ...
- 20165220预备作业3 Linux安装及学习
首先对于这第三次作业而言,给我的准备时间确实不多,因为过年回老家6天,没有办法及时的进行学习和思考,回到家中便草草的看了下相关操作跟教程从而完成了作业,这次主要是学习一些基础操作,为开学的Java学习 ...
- JavaEE 之 Habernate
1.Habernate a.定义:Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO(简单java对象,即javabean)与数据库表建立映射关 ...
- Elasticsearch 基于 URL 的搜索请求
背景 Elasticsearch 不像关系型数据库,没有简易的 SQL 用来查询数据,只能通过调用 RESTful API 实现查询.大体上查询分为两种,基于 URL 的和基于请求主体的.基于 URL ...