列表理解中的 Numpy 数组划分导致大量 RAM 膨胀?

问题描述

我刚刚在列表理解中遇到了除法问题,我不确定如何解决它,而且我也很好奇为什么会发生这种情况。

我有一个包含 30 张图片文件夹,总共 300MB(每个大约 12MB)

以下代码很好,加载图像没有问题:

import cv2

image_ids = [...] # contains the image names
images = [cv2.imread('data/' + id) for id in image_ids]

这消耗了大约 0.5GB 的内存,这仍然是相当多的开销,但也是合理的。 但后来我尝试了这段代码

import cv2

image_ids = [...] # contains the image names
images = [cv2.imread('data/' + id) / 255.0 for id in image_ids]

这个简单的修改导致 RAM 从 Python 的 1GB RAM 飙升到 5GB RAM。 我怎样才能以一种不会在内存中造成这么多垃圾的方式来做到这一点,为什么会发生这种情况?

事后我也尝试使用 gc.collect() 但它没有清除任何内存。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...