Python通过上下文管理器使用进程池multiprocessing.Pool
来源:互联网 发布:笔记本电池检测软件 编辑:程序博客网 时间:2024/05/20 09:07
进程池工具multiprocessing.Pool返回的对象其实是个上下文管理器。那么我们怎么知道multiprocessing.Pool对象是上下文管理器呢?我们看查看一下multiprocessing.Pool对象的属性,可以看到__enter__和__exit__函数,因此multiprocessing.Pool对象无疑是上下文管理器。
我们看一下__enter__和__exit__函数,__exit__函数里面是调用列terminate函数,所以如果通过上下文管理器方式使用就不用显式调用terminate函数了。
def __enter__(self): return selfdef __exit__(self, exc_type, exc_val, exc_tb): self.terminate()
通过上下文管理器使用Pool实例:
from multiprocessing import Pooldef add(x): return x + xif __name__ == '__main__': args = [1, 4, 7, 11] with Pool(processes=4) as pool: result = pool.map(add, args, 4) print(result)
普通方法使用Pool实例:
from multiprocessing import Pooldef add(x): return x + xif __name__ == '__main__': args = [1, 4, 7, 11] pool = Pool(processes=5) result = pool.map(add, args) pool.terminate() pool.join() # terminate之后调用,否则报错 print(result)
PS: 线程池工具multiprocessing.dummy.Pool类似,也是可以用上下文管理器。
from multiprocessing.dummy import Pooldef add(x): return x + xif __name__ == '__main__': args = [1, 4, 7, 11] with Pool(processes=4) as pool: result = pool.map(add, args) print(result)
阅读全文
0 0
- Python通过上下文管理器使用进程池multiprocessing.Pool
- python进程池:multiprocessing.pool
- python进程池:multiprocessing.pool
- python进程池:multiprocessing.pool
- python进程池:multiprocessing.pool
- python进程池:multiprocessing.pool
- 【Python】python进程池:multiprocessing.pool
- multiprocessing 进程池 pool
- Python多进程multiprocessing.Pool()
- Python多进程库multiprocessing中进程池Pool类的使用
- python进程池multiprocessing.Pool和线程池multiprocessing.dummy.Pool实例
- python multiprocessing dummy Pool 使用
- Python 多进程 multiprocessing.Pool类详解
- Python 多进程 multiprocessing Pool 坑
- Python 多进程 multiprocessing.Pool类详解
- python 多进程 —— multiprocessing.Pool
- Python 多进程 multiprocessing.Pool类详解
- 多进程multiprocessing-进程池Pool
- 获取函数内部值的两种方法
- 代理模式
- 设计模式精髓篇之行为型
- GSM —— 商业蜂窝通信系统
- HDU-2011(多项式求和)
- Python通过上下文管理器使用进程池multiprocessing.Pool
- 工具类学习
- C语言中可变参数列表解析
- 23种设计模式目录
- [Java笔记]之Concurrency
- springboot全局异常捕获
- 习题5.5
- Xshell5连接虚拟机中的Linux(Centos)的方法以及失败原因
- Rabbit添加用户