学习jvm,关于MAT an internal error occurred during:"Parsing heap dump" from问题

写了一个死循环不断的创建对象,模拟内存溢出

复制代码
 1 package com.zuo.test1;
 2 
 3 import java.util.ArrayList;
 4 import java.util.List;
 5 
 6 public class Main {
 7     
 8     public static void main(String[] args) {
 9         List<Demo> demos=new ArrayList<>();
10         while(true){
11             demos.add(new Demo());
12         }
13     }
14 
15     
16 }
复制代码

 

修改启动参数。 

Apply

 

运行。

出现堆溢出错误,这时就会在本项目下出现xxx.hprof

 

然后再使用MAT工具引入此文件。进行分析。

通过MAT发现heap dump问题所在,就需要寻找导致内存泄漏的代码点。这时往往需要打开对象依赖关系树形视图,点击如图按钮即可。 

 

 

 

为了更有效率的使用 MAT,我们可以配置一些环境参数。因为通常而言,分析一个堆转储文件需要消耗很多的堆空间,为了保证分析的效率和性能,在有条件的情况下,我们会建议分配给 MAT 尽可能多的内存资源。你可以采用如下两种方式来分配内存更多的内存资源给 MAT。

一种是修改启动参数 MemoryAnalyzer.exe-vmargs -Xmx4g

另一种是编辑文件 MemoryAnalyzer.ini,在里面添加类似信息 -vmargs– Xmx4g。

说明:

1. MemoryAnalyzer.ini中的参数一般默认为-vmargs– Xmx1024m,这就够用了。假如你机器的内存不大,改大该参数的值,会导致MemoryAnalyzer启动时,报错:Failed to create the Java Virtual Machine。

2.当你导出的dump文件的大小大于你配置的1024m(说明1中,提到的配置:-vmargs– Xmx1024m),MAT输出分析报告的时候,会报错:An internal error occurred during: "Parsing heap dump from XXX”。适当调大说明1中的参数即可。

 

本文作者:ZzUuOo666

本文链接:https://www.cnblogs.com/zzuuoo666/p/9029419.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   ZzUuOo666  阅读(4886)  评论(0编辑  收藏  举报
编辑推荐:
· Kafka 的“无锁哲学”:高效消息流动的背后
· 时间轮在 Netty , Kafka 中的设计与实现
· MySQL 优化利器 SHOW PROFILE 的实现原理
· 在.NET Core中使用异步多线程高效率的处理大量数据
· 聊一聊 C#前台线程 如何阻塞程序退出
阅读排行:
· 3款.NET开源、功能强大的通讯调试工具,效率提升利器!
· 用 Cursor 写出第一个程序
· 如何做好技术经理
· 《HelloGitHub》第 105 期
· 盘点5个常用的.Net依赖注入框架!
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起