从Java堆转储中查看StringBuffer或char []的内容

时间:2015-07-02 19:28:12

标签: java heap visualvm jvisualvm heap-dump

我正在分析一个Java堆转储,寻找内存的高消费者。转储中超过50%的内存由两个StringBuffers使用,每个StringBuffers都包含一个char [],它自然地占据了相应StringBuffer中大部分内存的。但是,当我检查实例查看器中的char []时,内容被省略了,我想因为字符串太大了。我也尝试在VisualVM的OQL中使用.toString(),但这显然只适用于String对象。

有没有办法弄清楚这些数组的内容是什么?

1 个答案:

答案 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();
})