Python进程池与线程池

进程池

进程池:就是创建一定数量的进程 , 当有任务进来执行的时候 , 那么在池中的某一个进程进行处理任务 , 当进程处理任务完毕 之后不关闭 , 而是进入池中等到任务 。

进程池不会增加操作系统的调度难度 , 还节省了开闭进程的时间 , 在一定程度上能够事项并发效果

进程池的导入

# 进程池
from concurrent.futures import  ProcessPoolExecutor
# 线程池
from concurrent.futures import  ThreadPoolExecutor
from concurrent.futures import  ProcessPoolExecutor
import time
​
# 设置进程池对象 , 传入参数,就代表这个进程池的大小(有多少个进程)
# 没有参数,会默认开设当前计算机CPU个数的进程
pool_p = ProcessPoolExecutor(10)
​
​
def func(name):
    print(f'{name}')
    time.sleep(2)
​
​
if __name__ == '__main__':
    for i in range(20):
        pool_p.submit(func , i)
# submit(func , i)这个是有返回值的 , 返回的是Future对象 , 这个对象result方法,该方法是用来获取返回值的正在数据结果
from concurrent.futures import  ProcessPoolExecutor
import time
​
# 设置进程池对象 , 传入参数,就代表这个进程池的大小(有多少个进程)
# 没有参数,会默认开设当前计算机CPU个数的进程
pool_p = ProcessPoolExecutor(10)
​
​
def func(n):
    # print(f'{n}')
    time.sleep(2)
    return n + 1
​
​
if __name__ == '__main__':
    for i in range(20):
        res = pool_p.submit(func , i)
        print(res)  # 获取到Future对象
        print(res.result()) # 通过result方法获取到对象中每个任务返回的数据

# shutdown() 等待进程池中所有进程任务结束之后 , 在执行主进程
from concurrent.futures import  ProcessPoolExecutor
import time
​
# 设置进程池对象 , 传入参数,就代表这个进程池的大小(有多少个进程)
# 没有参数,会默认开设当前计算机CPU个数的进程
pool_p = ProcessPoolExecutor(10)
​
​
def func(n):
    # print(f'{n}')
    time.sleep(2)
    return n + 1
​
​
if __name__ == '__main__':
    # 将所有任务的返回值添加到列表
    ls = []
    for i in range(20):
        res = pool_p.submit(func , i)
        ls.append(res)
        print(res)  # 获取到Future对象
​
    # 等待进程池中所有进程任务结束之后 , 在执行主进程
    pool_p.shutdown()
    for i in ls:
        print(i.result()) # 通过result方法获取到对象中每个任务返回的数据
# 进程池/线程池有一个回调机制——add_done_callback()
from concurrent.futures import  ProcessPoolExecutor
import time
​
# 设置进程池对象 , 传入参数,就代表这个进程池的大小(有多少个进程)
# 没有参数,会默认开设当前计算机CPU个数的进程
pool_p = ProcessPoolExecutor(10)
​
​
def func(n):
    # print(f'{n}')
    time.sleep(2)
    return n + 1
​
def f(fun):
    print(f'获取到返回值结果{fun.result()}')
​
if __name__ == '__main__':
    # 将所有任务的返回值添加到列表
    ls = []
    for i in range(20):
        res = pool_p.submit(func , i)
        # 回调机制不需要对任务进行参数传递 , 参数会根据对象进行传入
        res.add_done_callback(f)

进程是依靠电脑的操作系统进行调度;

线程是依靠电脑的CPU进行调度;

那么两者的调度顺序也是有操作系统或者CPU使用的调度决定的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的进程线程池是用来进行并发处理任务的工具。进程是在一个子中放入固定数量的进程,当有任务到达时,就从子中拿一个进程来处理任务,处理完毕后再放回子中等待任务。进程的数量是固定的,因此同一时间最多有固定数量的进程在运行。这样可以避免增加操作系统的调度难度,并节省开闭进程的时间,实现并发效果。 在Python中,可以使用`concurrent.futures`模块中的`ProcessPoolExecutor`类来创建进程。通过实例化`ProcessPoolExecutor`类,可以获得一个指定大小的进程。例如,可以使用以下代码实例化一个进程并指定大小为整数`n`: ``` from concurrent.futures import ProcessPoolExecutor pool = ProcessPoolExecutor(n) ``` 其中`n`是进程的大小,即进程的数量。 线程池进程的原理类似,不同之处在于线程池是在一个子中放入固定数量的线程来处理任务。线程池的使用方式也类似,可以使用`concurrent.futures`模块中的`ThreadPoolExecutor`类来创建线程池,并指定大小。线程池的使用和进程类似,都是从子中获取线程或进程来处理任务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Python--进程线程池](https://blog.csdn.net/weixin_43988680/article/details/124284555)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值