1. 支配树
MAT提供了称为 支配树(Dominator Tree) 的对象图。支配树展示的是对象实例间的支配关系。在对象引用图中,所有指向对象B的路径都经过对象A,则认为对象A支配对象B。
2. 深堆和浅堆
- 支配树中对象本身占用的空间称之为浅堆(Shallow Heap)
- 支配树中对象的子树就是所有被该对象支配的内容,这些内容组成了对象的深堆(Retained Heap也称之为保留集(Retained Set )。深堆的大小表示该对象如果可以被回收,能释放多大的内存空间。
3. 案例
public class Main {
public static void main(String[] args) {
TestClass a1 = new TestClass();
TestClass a2 = new TestClass();
TestClass a3 = new TestClass();
String s1 = "str1";
String s2 = "str2";
String s3 = "str3";
a1.list.add(s1);
a2.list.add(s1);
a2.list.add(s2);
a3.list.add(s3);
}
}
class TestClass {
public List<String> list;
}
引用链:
支配树:
4. 总结
MAT就是根据支配树,从叶子节点向根节点遍历,如果发现深堆的大小超过整个堆内存的一定比例阈值,就会将其标记成内存泄漏的“嫌疑对象”