码迷,mamicode.com
首页 > 编程语言 > 详细

Python基础5

时间:2018-06-02 20:43:01      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:多进程   代码   模块   ssi   art   write   get   启动   queue   

多进程

multiprocessing模块提供了一个Process类来代表一个进程对象,下面的例子演示了启动一个子进程并等待其结束:

from multiprocessing import Process
import os

#子进程要执行的代码
def run_proc(name):
    print(Run child process %s (%s) % (name,os.getpid()))

if __name__==__main__:
    print(Parent process %s. % os.getpid())
    p=Process(target=run_proc,args=(test,))
    print(Child process will start.)
    p.start()
    p.join()  #join()方法可以等待子进程结束后再继续往下运行,通常用于进程间的同步。
    print(Child process end.)

Process之间肯定是需要通信的,操作系统提供了很多机制来实现进程间的通信。Python的multiprocessing模块包装了底层的机制,提供了QueuePipes等多种方式来交换数据。我们以Queue为例,在父进程中创建两个子进程,一个往Queue里写数据,一个从Queue里读数据:

from multiprocessing import Process, Queue
import os, time, random

# 写数据进程执行的代码:
def write(q):
    print(Process to write: %s % os.getpid())
    for value in [A, B, C]:
        print(Put %s to queue... % value)
        q.put(value)
        time.sleep(random.random())

# 读数据进程执行的代码:
def read(q):
    print(Process to read: %s % os.getpid())
    while True:
        value = q.get(True)
        print(Get %s from queue. % value)

if __name__==__main__:
    # 父进程创建Queue,并传给各个子进程:
    q = Queue()
    pw = Process(target=write, args=(q,))
    pr = Process(target=read, args=(q,))
    # 启动子进程pw,写入:
    pw.start()
    # 启动子进程pr,读取:
    pr.start()
    # 等待pw结束:
    pw.join()
    # pr进程里是死循环,无法等待其结束,只能强行终止:
    pr.terminate()

 

Python基础5

标签:多进程   代码   模块   ssi   art   write   get   启动   queue   

原文地址:https://www.cnblogs.com/larry-xia/p/9126376.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!