我正在尝试分析从java进程中获取的堆转储,它遇到了内存问题。转储是使用jmap获取的。我在转储文件中使用了jhat --我得到了
java.io.IOException: Unrecognized magic number: 169897589 at com.sun.tools.hat.internal.parser.Reader.readFile(Reader.java:94) at com.sun.tools.hat.Main.main(Main.java:159)
jdk 1.6和1.7都给出了相同的错误。我在本地的Windows机器上运行jhat (在复制转储文件之后),转储文件是在Linux服务器上获取的。
你知道我做错了什么吗?
发布于 2013-03-20 02:44:19
如果你看一下com.sun.tools.hat.internal.parser.Reader的源代码,你会发现它正在寻找神奇的数字0x4a415641。
该值用于帮助标识有效的堆转储文件。jmap应将此值附加为它创建的任何堆转储文件的前四个字节。
我建议在十六进制编辑器中打开堆转储,并检查前四个字节是否为0x4a415641。在您的Linux和Windows机器上检查该文件。当您传输文件时,可能文件已损坏。
https://stackoverflow.com/questions/15507047
复制相似问题