从 Java 堆转储中查看 StringBuffer 或 char[] 的内容
see contents of StringBuffer or char[] from a Java heap dump
我有一个正在分析的 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 堆转储,以寻找高内存消耗者。转储中超过 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();
})