博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python 3 多进程通信
阅读量:2158 次
发布时间:2019-05-01

本文共 1114 字,大约阅读时间需要 3 分钟。

from multiprocessing import Process, Queue, Lockfrom datetime import datetimeimport numpy as npimport timeimport osdef func1(q, lock):    print(f'get into func1: pid: {os.getpid()}')    for i in range(10):        d = {'fun_1': {str(i) + '-' + datetime.now().strftime('%H:%M:%S.%f'): np.random.randint(1000)}}        with lock:            q.put(d)        time.sleep(1)def func2(q, lock):    print(f'get into func2: pid: {os.getpid()}')    for i in range(10):        d = {'fun_2': {str(i) + '-' + datetime.now().strftime('%H:%M:%S.%f'): np.random.random()}}        with lock:            q.put(d)        time.sleep(1.5)def func3(q):    print(f'get into func3: pid: {os.getpid()}')    for i in range(30):        d = q.get()        if len(d):            print('fun3 received:')            print(d)            time.sleep(0.01)if __name__ == '__main__':    q = Queue()    lock = Lock()    p1 = Process(target=func1, args=(q, lock))    p1.daemon = True    p2 = Process(target=func2, args=(q, lock))    p2.daemon = True    p3 = Process(target=func3, args=(q, ))    p3.daemon = True    p1.start()    p2.start()    p3.start()

 

转载地址:http://emhwb.baihongyu.com/

你可能感兴趣的文章
走进JavaWeb技术世界1:JavaWeb的由来和基础知识
查看>>
走进JavaWeb技术世界2:JSP与Servlet的曾经与现在
查看>>
走进JavaWeb技术世界3:JDBC的进化与连接池技术
查看>>
走进JavaWeb技术世界4:Servlet 工作原理详解
查看>>
走进JavaWeb技术世界5:初探Tomcat的HTTP请求过程
查看>>
走进JavaWeb技术世界6:Tomcat5总体架构剖析
查看>>
走进JavaWeb技术世界7:Tomcat和其他WEB容器的区别
查看>>
走进JavaWeb技术世界9:Java日志系统的诞生与发展
查看>>
走进JavaWeb技术世界10:从JavaBean讲到Spring
查看>>
走进JavaWeb技术世界11:单元测试框架Junit
查看>>
走进JavaWeb技术世界12:从手动编译打包到项目构建工具Maven
查看>>
走进JavaWeb技术世界13:Hibernate入门经典与注解式开发
查看>>
走进JavaWeb技术世界14:Mybatis入门
查看>>
走进JavaWeb技术世界16:极简配置的SpringBoot
查看>>
初探Java设计模式1:创建型模式(工厂,单例等)
查看>>
初探Java设计模式2:结构型模式(代理模式,适配器模式等)
查看>>
初探Java设计模式3:行为型模式(策略,观察者等)
查看>>
初探Java设计模式4:一文带你掌握JDK中的设计模式
查看>>
初探Java设计模式5:一文了解Spring涉及到的9种设计模式
查看>>
Java集合详解1:一文读懂ArrayList,Vector与Stack使用方法和实现原理
查看>>