调用System.gc没有立即执行的解决方法

原创 2016年08月31日 16:49:35

查看源码

当我们调用System.gc()的时候,其实并不会马上进行垃圾回收,甚至不一定会执行垃圾回收,查看系统源码可以看到


    /**
     * Indicates to the VM that it would be a good time to run the
     * garbage collector. Note that this is a hint only. There is no guarantee
     * that the garbage collector will actually be run.
     */
    public static void gc() {
        boolean shouldRunGC;
        synchronized(lock) {
            shouldRunGC = justRanFinalization;
            if (shouldRunGC) {
                justRanFinalization = false;
            } else {
                runGC = true;
            }
        }
        if (shouldRunGC) {
            Runtime.getRuntime().gc();
        }
    }

也就是justRanFinalization=true的时候才会执行

查找发现当调用runFinalization()的时候justRanFinalization变为true
下面是runFinalization()的源码


/**
* Provides a hint to the VM that it would be useful to attempt
* to perform any outstanding object finalization.
*/
public static void runFinalization() {
        boolean shouldRunGC;
        synchronized(lock) {
            shouldRunGC = runGC;
            runGC = false;
        }
        if (shouldRunGC) {
            Runtime.getRuntime().gc();
        }
        Runtime.getRuntime().runFinalization();
        synchronized(lock) {
            justRanFinalization = true;
        }
}

其实当我们直接调用System.gc()只会把这次gc请求记录下来,等到runFinalization=true的时候才会先去执行GC,runFinalization=true之后会在允许一次system.gc()。之后在call System.gc()还会重复上面的行为。
所以System.gc()要跟System.runFinalization()一起搭配使用才好。
查看ZygoteInit.java 里面 gc()和runFinalizationSync()是配合使用的,这样才有效果

static void gcAndFinalize() {
    final VMRuntime runtime = VMRuntime.getRuntime();

    /* runFinalizationSync() lets finalizers be called in Zygote,
    * which doesn't have a HeapWorker thread.
    */
    System.gc();
    runtime.runFinalizationSync();
    System.gc();
}

解决方案

由此可见,当我们需要调用的System.gc()的时候 要这样才会执行

System.gc();
runtime.runFinalizationSync();
System.gc();

不过个人建议不到万不得已不要调用,因为jvm有自己的gc策略,根本不需要我们来手动

转载请注明出处:http://www.weyye.me/detail/System-gc-not-called/

版权声明:本文为博主原创文章,未经博主允许不得转载。

浅谈Java中的System.gc()的工作原理

趁着今天写程序的热乎劲儿,小谈一下System.gc()这个神秘的东东~很多人把Java的“效率低下”归咎于不能自由管理内存,但我们也知道将内存管理封装起来的好处,这里就不赘述。Java中的内存分配是...
  • huxin1
  • huxin1
  • 2010年10月11日 11:05
  • 39171

java垃圾回收那点事(一) System.gc开始说起

java提供了从语言角度能够强制jvm进行垃圾回收,在我们的程序中会通过调用System.gc去强制jvm进行垃圾回收,通过源码我们可以看到实际上是调用了Runtime去强制gc public sta...

调用System.gc没有立即执行

原文链接http://www.weyye.me/detail/System-gc-not-called/ 查看源码 当我们调用System.gc()的时候,其实并不会马上进行垃圾回收,甚至...

System.gc(); 与Runtime.gc()的区别

(1) GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能可以自动监测对象...

java垃圾回收与System.gc()介绍

java垃圾回收与System.gc()介绍 1.垃圾收集算法的核心思想   Java语言建立了垃圾收集机制,用以跟踪正在使用的对象和发现并回收不再使用(引用)的对象。该机制可以有效防范动态内存分配...

Android System.gc()注意点

背景在看square Leakcanary源码时,提到用Runtime.getRuntime().gc()比直接调用System.gc()更容易触发gc,为什么呢?...
  • fearGod
  • fearGod
  • 2015年06月04日 17:18
  • 7440

常见对象_System类中垃圾回收的方法gc()的应用

package cn.itcast_01; /* * System:类包含一些有用的类字段和方法。它不能被实例化。 * * 方法: * public static void gc():...

android垃圾回收机制及程序优化System.gc

android垃圾回收机制及程序优化System.gc By admin on 2013/07/20 1.垃圾收集算法的核心思想   Java语言建立了垃圾收集机制,用以跟踪正在使用的对...

GC 垃圾回收机制彻底理解

垃圾回收器负责回收所有无任何引用对象的内存空间。 注意:垃圾回收回收的是无任何引用的对象占据的内存空间而不是对象本身。 1. System.gc();   Runtime.getRunti...

Dalvik虚拟机垃圾收集(GC)过程分析

前面我们分析了Dalvik虚拟机堆的创建过程,以及Java对象在堆上的分配过程。这些知识都是理解Dalvik虚拟机垃圾收集过程的基础。垃圾收集是一个复杂的过程,它要将那些不再被引用的对象进行回收。一方...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:调用System.gc没有立即执行的解决方法
举报原因:
原因补充:

(最多只允许输入30个字)