线程与进程代码示例

import multiprocessing
import concurrent.futures

# 分割成list
def data_split(batch_data, batch_num):
    split_data = [[] for _ in range(batch_num)]
    for i, data in enumerate(batch_data):
        split_data[i%batch_num].append(data)
    
    return split_data

# 分割成dict
'''
def data_split(self, batch_data, batch_num):
	split_data = [{} for _ in range(batch_num)]
	for i, data in enumerate(batch_data.items()):
	    split_data[i%batch_num][data[0]] = data[1]
	return split_data
'''

num_threads = multiprocessing.cpu_count()  # 获取CPU核心数
batch_data = data_split(export_data, num_threads)

executor = concurrent.futures.ThreadPoolExecutor(max_workers=num_threads)
    
for i in range(num_threads):
     executor.submit(err_vis.draw_all_info, batch_data[i])

# 关闭线程池
executor.shutdown(wait=True)

多进程

import multiprocessing

def data_split(batch_data, batch_num):
    split_data = [[] for _ in range(batch_num)]
    for i, data in enumerate(batch_data):
        split_data[i % batch_num].append(data)
    return split_data

num_processes = multiprocessing.cpu_count()  # 获取CPU核心数
batch_data = data_split(export_data, num_processes)

processes = []
for i in range(num_processes):
    p = multiprocessing.Process(target=err_vis.draw_all_info, args=(batch_data[i],))
    p.start()
    processes.append(p)

for p in processes:
    p.join()

import multiprocessing

def process_data(data):
    err_vis.draw_all_info(data)

num_processes = multiprocessing.cpu_count()  # 获取CPU核心数
batch_data = data_split(export_data, num_processes)

with multiprocessing.Pool(processes=num_processes) as pool:
    pool.map(process_data, batch_data)

同步调用

from multiprocessing import Pool
import time,os,random
def test(n):
    print(f"子进程:{os.getpid()}")
    time.sleep(2)
    return n*random.randint(2,9)

if __name__ == '__main__':
    n = os.cpu_count()     # 本机CPU个数,我的是4,进程池容量个数自定义,默认CPU核数
    p = Pool(processes=n)  # 设置进程池进程个数,从无到有,并且以后一直只有这四个进程在执行任务
    li = []
    start_time = time.time()
    for i in range(10):
        res = p.apply(test,args=(2,))  # 创建十个个任务, 使用同步调用的方式
        li.append(res)
    p.close()  # 先关闭进程池, 不会再有新的进程加入到pool中, 防止进一步的操作(同步调用可以不加此方法)
    p.join()   # 必须在close调用之后执行, 否则报错, 执行后等待所有子进程结束(同步调用可以不加此方法)
    print(li)  # 同步调用, 得到的就是最终结果,(异步调用得到的是对象, 需要使用get方法取值)
    print(f'使用时间:{time.time()-start_time}')
    
'''输出
子进程:7768
子进程:16276
子进程:17544
子进程:15680
子进程:7768
子进程:16276
子进程:17544
子进程:15680
子进程:7768
子进程:16276
[4, 18, 14, 14, 12, 14, 16, 14, 6, 10]
使用时间:20.226498126983643
'''
异步调用
from multiprocessing import Pool
import time,os,random

def test(n):
    print(f"子进程:{os.getpid()}")
    time.sleep(2)
    return n*n*random.randint(2,9)

if __name__ == '__main__':
    n = os.cpu_count()     # 本机CPU个数,我的是4,进程池容量个数自定义,默认CPU核数
    p = Pool(processes=n)  # 设置进程池大小, 从无到有, 并之后只有这四个进程执行任务
    li = []
    start_time = time.time()
    for i in range(10):
        res = p.apply_async(test,args=(2,))  # 开启十个任务, 使用异步调用的方式
        li.append(res)
    p.close()  # 关闭进程池, 不会再有新的进程加入到pool中, 防止进一步的操作
    p.join()   # join必须在close函数之后进行, 否则报错, 执行后等待所有子进程结束
    print(li)  # 返回的是AsyncResul的对象[<multiprocessing.pool.ApplyResult object at 0x000002318511B408>,....]
    print([i.get() for i in li])  # 使用get方法来获取异步调用的值(同步调用没有该方法),并放入列表中打印
    print(f"使用时间:{time.time()-start_time}")

'''输出
子进程:8636
子进程:10828
子进程:7432
子进程:13976
子进程:8636
子进程:10828
子进程:7432
子进程:13976
子进程:8636
子进程:10828
[<multiprocessing.pool.ApplyResult object at 0x000001623059B308>,...省略]
[16, 24, 24, 24, 16, 28, 36, 28, 8, 32]
使用时间:6.301024436950684
'''

同步调用和异步调用
http://t.csdn.cn/wNoEA

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Fighting_1997

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值