java – 如何防止Logcat中的GC_CONCURRENT语句
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java – 如何防止Logcat中的GC_CONCURRENT语句,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2356字,纯文字阅读大概需要4分钟。
内容图文
![java – 如何防止Logcat中的GC_CONCURRENT语句](/upload/InfoBanner/zyjiaocheng/823/15590d7585474059802f2a5e5f5dcef5.jpg)
我要求我需要检查文件’A’中的no.of行,如果文件’A’超出我的限制,那么我需要将其内容复制到其他文件’B’然后清除文件的内容’一个’.
上面的任务我必须一直执行所以,我构建了“服务”来完成这个任务. (我想在后面运行这个).
从服务我启动一个线程来执行上述任务.(我在Service中有其他任务应该与任务并行运行).
我正在使用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日志并使我的应用程序内存高效.
解决方法:
你在循环中创建了太多的“新”对象,这导致GC在你将它们取出之后进行野外清理.您希望使它们成为静态类变量,而不是新的局部变量,以便您可以继续使用相同的对象.
内容总结
以上是互联网集市为您收集整理的java – 如何防止Logcat中的GC_CONCURRENT语句全部内容,希望文章能够帮你解决java – 如何防止Logcat中的GC_CONCURRENT语句所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。