System.gc();

运行垃圾收集器。

调用gc方法表明,Java虚拟机将花费更多精力来回收未使用的对象,以使它们当前占用的内存可用于快速重用。当控件从方法调用返回时,Java虚拟机将尽最大努力从所有丢弃的对象中回收空间。

不建议。

在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。)