3 回答
TA贡献1900条经验 获得超5个赞
似乎没有人提到将对象引用显式设置为null
,这是一种“释放”您可能要考虑的内存的合法技术。
例如,假设您List<String>
在方法开始时就声明了a ,该方法的大小会变得非常大,但只需要在方法进行到一半时才需要。此时,您可以将List引用设置为,null
以允许垃圾回收器在方法完成之前可能回收该对象(并且无论如何该引用都超出范围)。
请注意,实际上我很少使用这种技术,但是在处理非常大的数据结构时值得考虑。
TA贡献1785条经验 获得超4个赞
System.gc();
运行垃圾收集器。
调用gc方法表明,Java虚拟机将花费更多精力来回收未使用的对象,以使它们当前占用的内存可用于快速重用。当控件从方法调用返回时,Java虚拟机将尽最大努力从所有丢弃的对象中回收空间。
不建议。
编辑:我在2009年写了原始回复。现在是2015年。
在Java诞生的20多年来,垃圾收集器一直在稳步改善。此时,如果您要手动调用垃圾收集器,则可能需要考虑其他方法:
如果你强迫机器上数量有限GC,它可能是值得拥有的负载均衡点远从目前的机器,等待它完成投放到连接的客户端,超时一段时间后悬挂的连接,然后就硬-重新启动JVM。这是一个糟糕的解决方案,但是如果您正在查看System.gc(),则强制重启可能是一个权宜之计。
考虑使用其他垃圾收集器。例如,(过去六年中的新产品)G1收集器是一种低暂停时间模型;它总体上使用更多的CPU,但最好不要强迫执行硬停止。由于服务器CPU现在几乎都具有多个内核,因此这是一个非常不错的选择。
查看调整内存使用情况的标志。尤其是在Java的较新版本中,如果没有那么多长期运行的对象,请考虑增加堆中newgen的大小。newgen(年轻)是分配新对象的位置。对于Web服务器,为请求创建的所有内容都放在此处,如果此空间太小,Java将花费额外的时间将对象升级到寿命更长的内存,在这些内存中销毁它们的代价更高。(如果newgen太小,您将为此付出代价。)例如,在G1中:
XX:G1NewSizePercent(默认为5;可能没有关系。)
XX:G1MaxNewSizePercent(默认为60;可能会提高它。)
考虑告诉垃圾收集器您暂停较长时间后还不满意。这将导致更频繁的GC运行,以使系统保持其余约束。在G1中:
XX:MaxGCPauseMillis(默认为200。)
添加回答
举报