java - 如何最小化 GC_FOR_ALLOC 的出现?

标签 java android memory-management garbage-collection dalvik

我的应用程序导致这些可怕的 GC_FOR_ALLOC 在特定位置(方法)多次发生:

12-29 22:20:30.229: D/dalvikvm(10592): GC_FOR_ALLOC freed 1105K, 14% free 10933K/12615K, paused 33ms, total 34ms
12-29 22:20:30.260: D/dalvikvm(10592): GC_FOR_ALLOC freed 337K, 13% free 11055K/12615K, paused 25ms, total 26ms
12-29 22:20:30.288: D/dalvikvm(10592): GC_FOR_ALLOC freed 278K, 14% free 10951K/12615K, paused 24ms, total 24ms
12-29 22:20:30.495: D/dalvikvm(10592): GC_CONCURRENT freed 633K, 11% free 11317K/12615K, paused 16ms+3ms, total 79ms
12-29 22:20:30.495: D/dalvikvm(10592): WAIT_FOR_CONCURRENT_GC blocked 16ms
12-29 22:20:30.499: D/dalvikvm(10592): WAIT_FOR_CONCURRENT_GC blocked 15ms

我很清楚我在内存管理方面做错了(是的,垃圾收集很棒,但仍然不能让我免于知道何时以及如何分配的责任)。

您能否推荐一种故障排除方法或技术,可以引导我找到有问题的代码行和可能的解决方案?

最佳答案

Android DDMS 是 eclipse 中 Android 开发工具的一部分,它有非常有用的工具,可用于分析和内存分配跟踪。

下面的截图突出显示了其中一些工具(都在 DDMS 下),一些工具需要通过单击左侧面板中的相应按钮(以红色突出显示)来激活,然后您可以在通过选择您要观看的标签(以蓝色突出显示)来打开右侧面板

堆和分配跟踪器在您的情况下将非常有用。

eclipse screenshot showing profiling and memory allocation tools

关于java - 如何最小化 GC_FOR_ALLOC 的出现?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14088159/

相关文章:

c++ - 我可以控制在 C++ 中复制到 CPU 缓存中的内容吗?

java - 动态填充 thymeleaf 中的列表

java - 如何使用 WIX、JAVA 和 MAVEN 构建 MSI

java - 激活/停用复选框 Java Swing

java - 安卓按钮无法点击

perl - 为什么 Perl 在打印文件时会占用我的内存 (RAM)?

java - draw.String() 和 fillRect() 使用相同的传递坐标写入 JFrame 上的不同位置

android - 在不调用外部服务器的情况下获取互联网 ip

android - Simpleperf 不记录任何样本

C: sbrk() 地址升序还是降序?