zoukankan      html  css  js  c++  java
  • MAT 分析dump文件

    public class OOM {
        private static List<Byte[]> list = new ArrayList<Byte[]>();
        public static void main(String[] args) {
            Zip zip = new Zip();
            zip.test(list);
        }
    }
    public class Zip {
        private List<Byte[]> a = null;
    
        public List<Byte[]> getA() {
            return a;
        }
    
        public void setA(List<Byte[]> a) {
            this.a = a;
        }
        public void test(List<Byte[]> list){
            Zip n = new Zip();
            n.setA(list);
            R r = new R();
            r.test1(n);
        }
    }
    public class R {
        public void test1(Zip z){
            while(true){
                Byte[] b = new Byte[100000];
                z.getA().add(b);
            }
        }
    }

    我刻意的制造了一段会溢出的代码。

    首先你可能需要改一下mat的配置文件。

    通过下图的leak suspects分析是可以看出gc root的。比较代码和图中的b a。

     还有其他的方式可以分析,点击dominator tree可以获取到持有大对象的线程,然后在其上也可以执行gcroot的分析,如下图。

     

    最后说的话,

    实际情况没有这么清晰的。你可能需要把gc root路径上的每一个都点一点来寻找到底哪里发生了问题。

  • 相关阅读:
    《linux 必读》
    ldd ldconfig
    rpm 数据库
    /bin, /sbin & /usr/bin, /usr/sbin & /usr/local/bin, /usr/local/sbin & glibc
    POSIX
    CentOS 下载地址
    insert into TABLE by SELECT ...
    httpd 处理模型
    http 状态码
    IP地址 0.0.0.0 是什么意思?
  • 原文地址:https://www.cnblogs.com/coolgame/p/12157954.html
Copyright © 2011-2022 走看看