我正在分析一个 Java 堆转储,寻找内存的高消耗者。转储中超过 50% 的内存被两个 StringBuffer 使用,每个 StringBuffer 都包含一个 char[],它(自然)占据了各自 StringBuffer 中的大部分内存。但是,当我在实例查看器中检查 char[] 时,内容被忽略,我认为是因为字符串太大了。我还尝试过在 VisualVM 的 OQL 中使用 .toString()
,但这显然只适用于 String 对象。
有什么方法可以找出这些数组的内容是什么?
最佳答案
您可以尝试使用以下 OQL 将所有 StringBuffer
实例的内部字符数组的内容写入磁盘:
map(heap.objects('java.lang.StringBuffer'),
function(it, index) {
var writer = new java.io.FileWriter("c:/temp/oql/stringbuffer_0x" + it.id.toString(16) + ".txt");
var chars = it.value;
for (var i=0; i<chars.length; i++) {
writer.write(chars[i]);
}
writer.close();
})
关于java - 从 Java 堆转储中查看 StringBuffer 或 char[] 的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31193033/