我正在分析一个Java堆转储,寻找内存的高消费者。转储中超过50%的内存由两个StringBuffers使用,每个StringBuffers都包含一个char [],它自然地占据了相应StringBuffer中大部分内存的。但是,当我检查实例查看器中的char []时,内容被省略了,我想因为字符串太大了。我也尝试在VisualVM的OQL中使用.toString()
,但这显然只适用于String对象。
有没有办法弄清楚这些数组的内容是什么?
答案 0 :(得分:1)
您可以尝试使用以下OQL将所有StringBuffer
实例的内部char数组的内容写入磁盘:
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();
})