gpt4 book ai didi

Python多处理 - 进程完成后如何释放内存?

转载 作者:IT老高 更新时间:2023-10-28 22:25:05 27 4
gpt4 key购买 nike

我在使用 python 多处理库时遇到了一个奇怪的问题。

我的代码如下所示:我为每个“符号、日期”元组生成一个进程。之后我结合结果。

我希望当一个进程完成对“符号,日期”元组的计算时,它应该释放它的内存吗?显然情况并非如此。我看到几十个进程(尽管我将进程池的大小设置为 7)在机器中挂起¹。它们不消耗 CPU,也不释放内存。

如何让进程在完成计算后释放其内存?

谢谢!

¹“暂停”是指它们在 ps 命令中的状态显示为“S+”

def do_one_symbol( symbol, all_date_strings ):
pool = Pool(processes=7)
results = [];
for date in all_date_strings:
res = pool.apply_async(work, [symbol, date])
results.append(res);

gg = mm = ss = 0;
for res in results:
g, m, s = res.get()
gg += g;
mm += m;
ss += s;

最佳答案

您是否尝试使用 pool.close 关闭池?然后等待进程通过 pool.join 完成,因为如果父进程继续运行并且不等待子进程,它们将变为 zombies

关于Python多处理 - 进程完成后如何释放内存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7648967/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com