胖大海瘦西湖
2015-06-04 10:36Python如何实现多线程与多进程的配合工作?
#!/usr/bin/env python
#coding=utf8
import multiprocessing
import threading
import threadpool
import time
import re
import os
'''
想法:
开启了11个进程,第一个进程是以多线程方式运行,再通过进程间通信来使其他进程工作.
'''
def put_test(str1): # 处理出函数名,开启多线程
print str1,
q.put(str1)
time.sleep(1)
def get_test(): # 进程池除第一个以外的进程
print ' 5'
print q.qsize(),os.getpid()
print q.get(True,1)
time.sleep(1)
###############################################################
if name=='__main__':
multiprocessing.freeze_support()
q=multiprocessing.Queue(maxsize = 10)
# 线程池
data=range(1,11)
pool=threadpool.ThreadPool(10)
requests=threadpool.makeRequests(put_test,data)
[pool.putRequest(req) for req in requests]
pool.wait()
# 进程池
pool2 = multiprocessing.Pool(processes=3)
for var in range(1,11): # 20个进程
pool2.apply_async(get_test,[])
pool2.close()
pool2.join()
print "size:",q.qsize()
这段代码出问题了,求助。
- 点赞
- 回答
- 收藏
- 复制链接分享
2条回答
为你推荐
- 为什么python使用线程池会丢失部分数据?
- python
- 1个回答
- python的opencv打开两个摄像头失败
- python
- 1个回答
- Python多进程修改共享变量的问题
- python
- 3个回答
- 基于线程开发一个FTP服务器
- python
- 1个回答
- 这是个PYHTON线程和进程的问题
- python
- 1个回答