0

我有一个针对复杂问题的多目标粒子群优化算法,它使用大量(4000 个粒子)并且是一个耗时的模拟(执行 4 - 6 小时)。

由于算法保存了一个存档,一个迄今为止找到的最佳解决方案的存储库,为了分析算法收敛和行为,我需要从这个存储库中保存一些数据,有时在每次迭代时从整个种群中保存一些数据。

目前在每次迭代中,我(用 Java 语言)从粒子的对象(从存储库和/或总体)复制一些属性,将其格式化为 StringBuffer,该方法在与模拟不同的线程中运行,并且仅在程序执行结束我将它保存到一个文本文件中。

我认为我的算法这样做会以一种糟糕的方式消耗内存。但是考虑到性能,我不知道保存所有这些数据的最佳方法是什么:我应该遵循相同的逻辑,但每次迭代都保存一个 .txt 文件,而不是在算法结束时保存吗?还是我应该保存到数据库?如果是这样,我应该在每次迭代中还是在最后或其他时间保存它?还是我应该以不同的方式处理它?

编辑:存储库数据通常在 [5 - 10] MB 范围内,而人口数据占用 [100 - 200] MB 内存。每次我运行程序时,我都需要大约 20 次模拟来分析平均收敛性。

4

1 回答 1

1

StringBuffer使用数组来保存字符,这是内存的连续区域。每当需要扩展它时,它都会创建一个大两倍的新数组。通常对于大多数应用程序来说已经足够了,但是如果您认为这个缓冲区可能非常大并且想要消除管理连续部分内存的开销,您可以将其替换为字符串列表(或 StringBuffers)。这将需要更多内存,但不需要此内存是连续的。

于 2012-12-17T21:52:20.733 回答