Python--多进程
来源:互联网 发布:java 强制停止线程 编辑:程序博客网 时间:2024/06/06 04:02
1.multiprocessing.Pool()方法
#用进程池的方式批量创建子进程:import multiprocessing#创建进程池pool_num=4#若不指定线程数量,默认为机器的cpu核数pool=multiprocessing.Poll(pool_num)#将map放入不同进程pool.map(function,list)#关闭进程池pool.close()#对Pool对象调用join()方法会等待所有子进程执行完毕,调用join()之前必须先调用close(),调用close()之后就不能继续添加新的Process了pool.join()
2.fork()方法
#摘自廖雪峰的官方网站
Unix/Linux系统下,fork()调用一次,返回两次,因为操作系统自动把当前进程(称为父进程)复制了一份(称为子进程),然后,分别在父进程和子进程内返回。
子进程永远返回0,而父进程返回子进程的ID。这样做的理由是,一个父进程可以fork出很多子进程,所以,父进程要记下每个子进程的ID,而子进程只需要调用getppid()就可以拿到父进程的ID。
由于Windows没有fork调用,上面的代码在Windows上无法运行。由于Mac系统是基于BSD(Unix的一种)内核,所以,在Mac下运行是没有问题的,
有了fork调用,一个进程在接到新任务时就可以复制出一个子进程来处理新任务,常见的Apache服务器就是由父进程监听端口,每当有新的http请求时,就fork出子进程来处理新的http请求。
# multiprocessing.pyimport osprint 'Process (%s) start...' % os.getpid()pid = os.fork()if pid==0: print 'I am child process (%s) and my parent is %s.' % (os.getpid(), os.getppid())else: print 'I (%s) just created a child process (%s).' % (os.getpid(), pid)运行结果如下:Process (876) start...I (876) just created a child process (877).I am child process (877) and my parent is 876.
3.multiprocessing.Process()
multiprocessing模块提供了一个Process类来代表一个进程对象,下面的例子演示了启动一个子进程并等待其结束:
join()方法可以等待子进程结束后再继续往下运行,通常用于进程间的同步。
from multiprocessing import Processimport osimport timedef run_proc(name): print 'Run child process %s (%s)...' % (name, os.getpid()) time.sleep(3)if __name__=='__main__': print 'Parent process %s.' % os.getpid() p = Process(target=run_proc, args=('test',)) print 'Process will start.' #因子进程设置了daemon属性,主进程结束,它们就随着结束了。 p.daemon=True p.start() p.join() print 'Process end.'#执行结果如下:Parent process 928.Process will start.Run child process test (929)...#此等待3sProcess end.
4.进程间通信
Python的multiprocessing模块包装了底层的机制,提供了Queue、Pipes等多种方式来交换数据。
eg:在父进程中创建两个子进程,一个往Queue里写数据,一个从Queue里读数据:
from multiprocessing import Process, Queueimport os, time, random# 写数据进程执行的代码:def write(q): for value in ['A', 'B', 'C']: print 'Put %s to queue...' % value q.put(value) time.sleep(random.random())# 读数据进程执行的代码:def read(q): while True: value = q.get(True) print 'Get %s from queue.' % valueif __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()
运行结果如下:
Put A to queue…
Get A from queue.
Put B to queue…
Get B from queue.
Put C to queue…
Get C from queue.
- PYTHON 多进程
- Python多进程
- python多进程编程
- Python 多进程
- python多进程编程
- {python多进程}
- python中的多进程
- Python多进程编程
- Python 多进程交互
- Python 多进程实例
- python 多进程实例
- python fork()多进程
- python多进程处理
- python 多进程
- Python 多进程
- python多进程
- python 多进程
- python 多进程
- 关于java ssh找不到驱动的问题
- 狡猾的商人 [bzoj1202,HNOI2005]
- IntelliJ IDEA像Eclipse一样打开多个项目
- Linux防火墙(iptables)的开启与关闭
- Creating Timers
- Python--多进程
- jackson 实体转json 为NULL或者为空不参加序列化
- Tsar开源:淘宝内部大量使用的系统监控工具
- mysql中float,double,decimal的差别
- Android sqlite数据库并发访问问题处理
- Nsight调试断点不停
- mybatis删除关键字数组对应项
- Java调用Runtime.getRuntime().exec(commandStr)来调用cmd执行指令
- activity启动模式