java.lang.OutOfMemoryError: 超出 GC 开销限制
2022-08-31 05:00:55
我在一个程序中收到此错误,该程序创建了几个(数十万个)HashMap对象,每个对象有几个(15-20)个文本条目。在提交到数据库之前,必须收集所有字符串(不要分解成较小的数量)。
根据Sun的说法,错误发生了“如果在垃圾回收中花费了太多时间:如果超过98%的总时间用于垃圾回收,并且不到2%的堆被恢复,则将抛出OutOfMemoryError。
显然,可以使用命令行将参数传递给 JVM
- 通过“-Xmx1024m”(或更多)增加堆大小,或
- 通过“-XX:-UseGCOverheadLimit”完全禁用错误检查。
第一种方法工作正常,第二种方法在另一个java.lang.OutOfMemoryError中结束,这次是关于堆的。
那么,问题:对于特定的用例(即,几个小的HashMap对象),是否有任何编程替代方案?例如,如果我使用HashMap clear()方法,问题就会消失,但存储在HashMap中的数据也会消失!:-)
StackOverflow 中的相关主题也讨论了这个问题。