System.gc()的理解

1、在默认情况下,通过System. gc()或者Runtime . getRuntime() .gc()的调用,会显式触发Full GC,同时对老年代和新生代进行回收,尝试释放被丢弃对象占用的内存。(System. gc()的底层就是Runtime . getRuntime() .gc() )

2、然而System. gc()调用附带一个免责声明,无法保证对垃圾收集器的调用。也就是说调用System. gc() JVM不一定会去Full GC,GC与否还是JVM说了算,这也算Java内存自动管理机制的一个特点了。

3、JVM实现者可以通过System. gc() 调用来决定JVM的GC行为。而一般情况下,垃圾回收应该是自动进行的,无须手动触发,否则就太过于麻烦了。在一些特殊情况下,如我们正在编写一个性能基准,我们可以在运行之间调用System.gc()。

4、System. gc()只是提醒JVM的垃圾回收器执行Full GC,但是不确定是否马上执行。System. gc()与Runtime . getRuntime().gc()的作用一样。

而System. runFinalization()方法:就是强制调用失去引用的对象的finalize()方法

5、空口无凭,直接演示一下,为了证明System.gc()的调用不一样会Full GC,我试了好几次,终于有一次没有GC。
System.gc()的理解 显式触发Full GC【代码证明】
6、为证明System.runFinalization()确实是强制执行没有引用的对象的finalize()方法,我运行了二十遍,虽然数据还是不够,但是尽力了。
System.gc()的理解 显式触发Full GC【代码证明】

两外:想全面的了解Java垃圾回收的知识见此文章,很详细。

有用点个关注,手留余香!???? ???? ????

相关文章:

  • 2022-12-23
  • 2021-08-26
  • 2021-06-05
  • 2021-08-14
  • 2021-11-02
  • 2021-11-12
猜你喜欢
  • 2022-12-23
  • 2021-09-11
  • 2022-12-23
  • 2022-12-23
  • 2022-01-26
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案