如何防止Logcat中的GC_CONCURRENT语句

时间:2011-08-18 15:52:57

标签: java android

我要求我检查文件'A'中的no.of行,如果文件'A'超出我的限制,那么我需要将其内容复制到其他文件'B'然后清除内容文件'A'。

上面的任务我必须一直执行所以,我构建了“服务”来完成这项任务。 (我想在后台运行它。)

从服务我启动一个线程来执行上述任务。(我在服务中有其他任务应该与任务并行运行。)

我正在使用AlarmManager让我的“服务”保持活力。

底线是上面的任务将一直运行。到目前为止,我成功实现了我想要实现的目标。

但我在LogCat输出中观察到它产生了与GC相关的巨大陈述。

像:

D/dalvikvm( 2579): GC_CONCURRENT freed 483K, 62% free 2608K/6727K, external 1628K/2108K, paused 2ms+2ms
D/dalvikvm( 2579): GC_CONCURRENT freed 469K, 62% free 2608K/6727K, external 1628K/2108K, paused 34ms+2ms
D/dalvikvm( 2579): GC_CONCURRENT freed 466K, 62% free 2608K/6727K, external 1628K/2108K, paused 1ms+2ms
D/dalvikvm( 2579): GC_CONCURRENT freed 472K, 62% free 2609K/6727K, external 1628K/2108K, paused 7ms+2ms
D/dalvikvm( 2579): GC_CONCURRENT freed 473K, 62% free 2607K/6727K, external 1628K/2108K, paused 2ms+1ms
D/dalvikvm( 2579): GC_CONCURRENT freed 473K, 62% free 2607K/6727K, external 1628K/2108K, paused 1ms+2ms
D/dalvikvm(  263): GC_EXPLICIT freed 351K, 58% free 3118K/7303K, external 10278K/11844K, paused 42ms 

我怀疑我的应用程序泄漏了一些内存,或者它耗费了大量内存。 关于性能我想避免这种情况。 下面是我一直在线程中运行的代码片段。

public void run()
{
    while (true) {
        if (WifiLogCollector.stoopThread)
            return;
        LineNumberReader lineNumberReader = new LineNumberReader(new FileReader(textfile));
        lineNumberReader.skip(Long.MAX_VALUE);

        if ((lineNumberReader.getLineNumber())  > 20000) {

            FileChannel source = null;
            FileChannel destination = null;

            try {
                source = new FileInputStream("/mnt/sdcard/textfile.txt").getChannel();
                destination = new FileOutputStream("/mnt/sdcard/textbackupfile.txt")
                                .getChannel();
                destination.transferFrom(source, 0, source.size());
            } finally {
                if (source != null) {
                    source.close();
                    source = null;
                }
                if (destination != null) {
                    destination.close();
                    destination = null;
                }
            }

            PrintWriter writer = new PrintWriter(/mnt/sdcard/textfile.txt);
            writer.print("");
            writer.close();
            writer = null;

        }

        lineNumberReader.close();
        lineNumberReader = null;
    }
}

以上是我的线程的run()方法。

请帮助我在设计中应该做的更改,以避免GC日志并使我的应用内存高效。

1 个答案:

答案 0 :(得分:5)

你在循环中创建了太多的“新”对象,这导致GC在你将它们取消之后进行野外清理。你想让它们成为静态类变量,而不是新的局部变量,这样你就可以继续使用相同的对象了。