1 Star 0 Fork 0

dragon/python5

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
multiprocess.py 998 Bytes
一键复制 编辑 原始数据 按行查看 历史
碎ping子 提交于 2015-04-27 22:59 . 多进程间通信
# encoding: utf-8
__author__ = 'zhanghe'
from multiprocessing import Process, Queue
import time
import random
def write(q):
"""
写数据进程执行的代码
:param q:
:return:
"""
for value in ['A', 'B', 'C']:
print 'Put %s to queue...' % value
q.put(value)
time.sleep(random.random())
def read(q):
"""
读数据进程执行的代码
:param q:
:return:
"""
while True:
value = q.get(True)
print 'Get %s from queue.' % value
if __name__ == '__main__':
# 父进程创建Queue,并传给各个子进程,一个写,一个读,从而实现进程间通信:
queue = Queue()
pw = Process(target=write, args=(queue,))
pr = Process(target=read, args=(queue,))
# 启动子进程pw,写入:
pw.start()
# 启动子进程pr,读取:
pr.start()
# 等待pw结束:
pw.join()
# pr进程里是死循环,无法等待其结束,只能强行终止:
pr.terminate()
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Python
1
https://gitee.com/dragon-teng140806/python5.git
[email protected]:dragon-teng140806/python5.git
dragon-teng140806
python5
python5
master

搜索帮助