multiprocessing中进程池,线程池的使用
multiprocessing
多进程基本使用
- 示例代码1
import time
import random
from multiprocessing import Process
def run(name):
print(f'{name} is running')
time.sleep(random.randint(1,3))
print(f'{name} is end')
if __name__ =='__main__':
p_list = []
for i in range(3):
# 传参的两种方式
# p = Process(target=run,kwargs={'name':f'线程{i}'})
p = Process(target=run,args=(f"线程{i}",))
p_list.append(p)
p.start()
# for i in p_list:
# p.join() # join后主进程会等待子进程都结束再结束
print('主进程结束')
# strat():方法的功能 1.开启进程 2.执行功能
- 示例代码2
import os
import time
import random
from multiprocessing import Process
class Run(Process):
def __init__(self,name):
super().__init__()
self.name = name
def run(self): # 必须实现run方法
print(os.getppid(),os.getpid())
print(f'{self.name} is running')
time.sleep(random.randint(1,3))
print(f'{self.name} is end')
if __name__ =='__main__':
p_list = []
for i in range(5):
p = Run(f'线程{i}')
p_list.append(p)
p.start()
for i in p_list:
p.join()
print('主进程结束',os.getpid())
进程池(from multiprocessing import Pool)
- 进程池原理
- 示例代码(串行)
import os
import time
from multiprocessing import Pool
def task(n):
print('{} is running'.format(os.getpid()))
time.sleep(2)
print('{} is done'.format(os.getpid()))
return n**2
if __name__ == '__main__':
# print(os.cpu_count()) #查看cpu个数
p = Pool(4) # 最大四个进程
for i in range(1,7): # 开7个任务
ret = p.apply(task,args=(i,)) #同步的,一个运行完才执行另一个
print(f'本次任务结束:{ret}')
p.close() # 禁止往进程池内在添加任务
p.join() # 等待进程池
print('主进程')
- 示例代码(并行)
import os
import time
from multiprocessing import Pool
def task(n):
print('{} is running'.format(os.getpid()))
time.sleep(2)
print('{} is done'.format(os.getpid()))
return n**2
if __name__ == '__main__':
# print(os.cpu_count()) #查看cpu个数
ret_lis = []
p = Pool(4) # 最大四个进程
for i in range(1,7): # 开7个任务
ret = p.apply_async(task,args=(i,)) # 异步的,一个运行完才执行另一个
ret_lis.append(ret)
p.close() # 禁止往进程池内在添加任务
p.join() # 等待进程池
# print('主进程')
print(_.get() for _ in ret_lis)
更多参数请参考:https://www.cnblogs.com/damumu/p/7321732.html
线程池(from multiprocessing.dummy import Pool)
- 线程池的原理
- 线程池首先会维护一个任务队列
- 生成工作使用的线程(可以是自定义个数,也可以是系统默认)
- 线程分别从队列中取出任务,并执行,一个任务执行完成需要告诉主线程完成一个任务
- 再从任务队列中取出任务,直到所有任务为空,退出线程
- 为什么需要使用线程池
- 创建/销毁线程伴随着系统开销,过于频繁的创建/销毁线程,会很大程度上影响处理效率。
记创建线程消耗时间T1,执行任务消耗时间T2,销毁线程消耗时间T3,如果T1+T3>T2,那说明开启一个线程来执行这个任务太不划算了!在线程池缓存线程可用已有的闲置线程来执行新任务,避免了创建/销毁带来的系统开销。
- 线程并发数量过多,抢占系统资源从而导致阻塞。
线程能共享系统资源,如果同时执行的线程过多,就有可能导致系统资源不足而产生阻塞的情况。
- 对线程进行一些简单的管理。
比如:延时执行、定时循环执行的策略等,运用线程池都能进行很好的实现。 - 示例代码
import requests
from multiprocessing.dummy import Pool
def get_source(url):
ret = requests.get(url)
return ret.text
def main():
urls = [
# ...,
# ...,
# ...,
]
pool = Pool(5)
ret_list = pool.map(get_source, urls)
pool.close()
# 调用join之前,先调用close函数,否则会出错。执行完close后不会有新的线程加入到pool,
# join函数等待所有子线程结束
pool.join()
for ret in ret_list:
print(ret)
print('*'*100)
# 更多关于dummy的介绍:https://my.oschina.net/zyzzy/blog/115096
if __name__ == '__main__':
main()
multiprocessing中进程池,线程池的使用的更多相关文章
- Python多进程库multiprocessing中进程池Pool类的使用[转]
from:http://blog.csdn.net/jinping_shi/article/details/52433867 Python多进程库multiprocessing中进程池Pool类的使用 ...
- concurrent.futures模块(进程池/线程池)
需要注意一下不能无限的开进程,不能无限的开线程最常用的就是开进程池,开线程池.其中回调函数非常重要回调函数其实可以作为一种编程思想,谁好了谁就去掉 只要你用并发,就会有锁的问题,但是你不能一直去自己加 ...
- Python-GIL 进程池 线程池
5.GIL vs 互斥锁(*****) 1.什么是GIL(Global Interpreter Lock) GIL是全局解释器锁,是加到解释器身上的,保护的就是解释器级别的数据 (比如垃圾回收的数据) ...
- 潭州课堂25班:Ph201805201 并发(进程与线程池) 第十四课 (课堂笔记)
循环执行一个线程 # -*- coding: utf-8 -*- # 斌彬电脑 # @Time : 2018/7/20 0020 5:35 import threading import queue ...
- Python学习之GIL&进程池/线程池
8.6 GIL锁** Global interpreter Lock 全局解释器锁 实际就是一把解释器级的互斥锁 In CPython, the global interpreter lock, or ...
- Python并发编程05 /死锁现象、递归锁、信号量、GIL锁、计算密集型/IO密集型效率验证、进程池/线程池
Python并发编程05 /死锁现象.递归锁.信号量.GIL锁.计算密集型/IO密集型效率验证.进程池/线程池 目录 Python并发编程05 /死锁现象.递归锁.信号量.GIL锁.计算密集型/IO密 ...
- Python标准模块--concurrent.futures 进程池线程池终极用法
concurrent.futures 这个模块是异步调用的机制concurrent.futures 提交任务都是用submitfor + submit 多个任务的提交shutdown 是等效于Pool ...
- python并发编程-进程池线程池-协程-I/O模型-04
目录 进程池线程池的使用***** 进程池/线程池的创建和提交回调 验证复用池子里的线程或进程 异步回调机制 通过闭包给回调函数添加额外参数(扩展) 协程*** 概念回顾(协程这里再理一下) 如何实现 ...
- 详解线程池的作用及Java中如何使用线程池
服务端应用程序(如数据库和 Web 服务器)需要处理来自客户端的高并发.耗时较短的请求任务,所以频繁的创建处理这些请求的所需要的线程就是一个非常消耗资源的操作.常规的方法是针对一个新的请求创建一个新线 ...
随机推荐
- 《一马当先 O2O创业真人秀》阿里云创客+项目提交报名中
传统行业与互联网的相互融合,线上与线下的互通,正在掀起一股“互联网+”新风潮和创业热潮.支付宝钱包.快的打车.淘点点……这些耳熟能详的应用早已成为人们生活的一部分.而越来越多的“互联网+”创新项目,将 ...
- AdobeCS3DesignPremiumChs_Greendown.cn使用注册机激活失败重新激活操作方法
解决Adobe Acrobat 9 Pro序列号无效/重新激活方法 1.删除C:\Program Files\Common Files\Adobe\Adobe PCD\cache\cache.db和C ...
- 线程间协作:wait、notify、notifyAll
线程间协作:wait.notify.notifyAll 在 Java 中,可以通过配合调用 Object 对象的 wait() 方法和 notify()方法或 notifyAll() 方法来实现线程间 ...
- M-PalindromeP-DP
Palindrome Partitioning 动态规划+深度优先搜索 https://leetcode.com/discuss/23480/c-solution-with-dp-and-dfs-12 ...
- Realtek无线网卡对于Ubuntu的WiFi不支持的处理办法
1.应急办法:查询rfkill list all,可以看到ideapad_laptop的无线被物理关闭,可是博主的笔记本根本没这个键位,所以执行sudo modprobe -r ideapad_lap ...
- TFS--解决新创建的windows用户无法访问TFS的问题
今天入职新同事,帮忙配置TFS的账号碰到一个问题,TFS账号是映射取administrators组得 所以新建用户之后,无法马上引入TFS.查询原因是 Builtin组中没有该账号,以前也总是碰到新加 ...
- 利用Kali进行WiFi钓鱼测试实战
文中提及的部分技术可能带有一定攻击性,仅供安全学习和教学用途,禁止非法使用.请不要做一只咖啡馆里安静的猥琐大叔. 写在前面 从至少一年前我就一直想在自己跑kali的笔记本上架个钓鱼热点.然而由于网上的 ...
- 021logging模块
##importlogging logging.debug('debug message')logging.info('info message')logging.warning('warning ...
- SSH2整合需要jar包解释
hibernate3.jar, Hibernate的库,必须使用的jar包 antlr-2.7.6.jar, 语法分析生成器 语言转换工具,hibernate利用它实现HQL到SQL的转换 cglib ...
- Java对象表示方式1:序列化、反序列化的作用
1.序列化是的作用和用途 序列化:把对象转换为字节序列的过程称为对象的序列化. 反序列化:把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存 ...