java - 垫 : How do you diagnose "x instances of "byte[ ]", loaded by "<system class loader >"occupy y (z%) bytes" memory issues?

标签 java android memory-management memory-leaks eclipse-mat

我正在尝试诊断我的 Android 应用程序中的内存问题。我转储了一个 HPROF 文件并将其加载到 Eclipse MAT 工具中(参见 How to analyze memory using android studio)。我现在正试图弄清列出的“泄漏嫌疑人”

我想知道以下是否表明存在真正的问题:

23 instances of "byte[]", loaded by "<system class loader>" occupy 5,504,576 (12.74%) bytes.

Biggest instances:

byte[1077600] @ 0x43c523e0 rM!.rM!.tO#.wR&.zU).}X,..[/..]1..[/..[/..\0..\0..[/..Z...[/..\0..]7..]7..^8..^8..]7..\6.}Z4.}Z4.|Z4.|Z4.{Y3.zX2.zX2.zX2.zX2.{Y3.xX2.wW1.vV0.uU/.tS0.sR/.qS/.qS/.qS/.oQ-.oQ/.pR0.pS1.pS1.oR0.mP..sN1.sN1.sN1.rM0.sO/.sO/.uN/.uN/.xO/.xO/.xP-.wO,.yN+.yN+.{P-.|Q..... - 1,077,616 (2.49%) bytes.
byte[960000] @ 0x4383ef88 ................................................................................................................l.y.n.{.}...........................................l}s............................................................................................ - 960,016 (2.22%) bytes.
byte[563200] @ 0x42bd8c40 7@/. )..!*..)0 .'...!(..#'..04%.15'./6&.3;&.DL5.NX@.AJ5.0;*.1<,.AN<.6C1.0;*.-6%.*1!./3$.24&./0".+3../7 .6:).=A3.YZT.hhf._]`.caf.STV.[]\.GLH.@E?.KQG.JRE.BJ;.9B1.04..9C .=J..7H..>L2.RZO.[`\.[[Y.ceb.fhe.ikh.gif.bda._a^.ac`.egd.ad].^aZ.[^W.[^W.\_X.\_X.Z]V.WZS.... - 563,216 (1.30%) bytes.
byte[563200] @ 0x42c69660 46+.)+ .%'..%&.."#..#$..&'!.%& .%'..')..)+ .+-".,.#.+-".)+ .(*..,.#.+-".*,!.*,!.)+ .)+ .*,!.*,!.)+ .(*..(*..)+ .,.#..0%./1&./1&.,-%.*+#.()!.'( .'( .'( .&'..$%..&&..&&..&&..&&..&&..&&..&&..&&..'&!.'&!.'&!.'&!.'&!.'&!.'&!.'&!.** .++!...$.11%.33'.34&.23%.23%.... - 563,216 (1.30%) bytes.
byte[563200] @ 0x42cf7310 ---................................................................................................................................................................................................................................................................ - 563,216 (1.30%) bytes.
byte[563200] @ 0x42d85fe8 ................................................................................................................................................................................................................................................................... - 563,216 (1.30%) bytes.
byte[563200] @ 0x42e13f10 ..................................................................................................................................................................}...}...}...}...|...|...|...|...{...{...{...{...{...{...{...{...{...{...{...{...{...{...{...{.... - 563,216 (1.30%) bytes.

如果是这样,您建议如何追踪它?如果不是,您知道这个字节数据可能是什么吗?

最佳答案

heapdumps 的问题在于,您确实需要了解应用程序行为的正常和异常情况。 “泄漏嫌疑人”可以为您提供指示器,但也可能让您误入歧途。

要确定字节数组的大小是否是问题所在,您可以检查它们到 GC 根的路径。这至少会告诉您字节数组的创建位置。

在使用 MAT 时,我个人总是查看支配树。它应该向您展示最大的物体。您还可以从那里按类加载器等分组。

这应该会给您更多见解。

关于java - 垫 : How do you diagnose "x instances of "byte[ ]", loaded by "<system class loader >"occupy y (z%) bytes" memory issues?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25749253/

相关文章:

java - 以相反的顺序读取和写入文件 - Java

java - 如何在不重复代码的情况下创建 JLabels(或其他元素)?

android - 阿尔卡特 OneTouch M Pop 5020D 的开发者选项?

c++ - OpenMP 和内存限制

java - 如何在JOOQ中编写多字段 `in`谓词?

java - GET 提交而不是 POST 提交。 Tapestry

java - 在整个 Android Java 项目中读取和修改列表的正确方法是什么?

android - 如何在 Android 中启动我的 APP 的辅助功能设置页面?

memory-management - SQLite是否愿意在可能的情况下将索引保留在其缓存中?

memory - Rust - 为什么 malloc/alloc 和更多 'idiomatic' 方法之间的内存使用差异如此之大