jmap命令结合mat插件分析内存泄露--OQL

http://smallnetvisitor.iteye.com/blog/1826434

 

User.java

复制代码
package gc;

import java.util.ArrayList;
import java.util.List;

/** 
 * @Package gc

 * @ClassName: User

 * @Description: TODO(这里用一句话描述这个类的作用)

 * @author andy

 * @date 2013-6-9 下午4:46:13

 */
public class User {
    private String id;  
    private String name;  
  
    public String getId() {  
        return id;  
    }  
  
    public void setId(String id) {  
        this.id = id;  
    }  
  
    public String getName() {  
        return name;  
    }  
  
    public void setName(String name) {  
        this.name = name;  
    }  
  
    public User(String id, String name) {  
        super();  
        this.id = id;  
        this.name = name;  
    } 
    
    
    public static void main(String[] args) {  
        List<User> list = new ArrayList<User>();  
        for (int i = 1; i < 10000; i++) {  
            User o = new User(i + "", System.currentTimeMillis() + "");  
            list.add(o);  
            o = null;  
        }  
        System.out.println("end");  
        try {  
            Thread.sleep(100000000l);  
        } catch (InterruptedException e) {  
            e.printStackTrace();  
        }  
    }  
}
复制代码


运行user任务管理器查看到的pid号:

 

基于jmap导出的堆信息:

 

用装了mat插件的eclipse打开firstHeap.bin文件

选择Leak Suspects Reports模式,finish

 

点击details

 

这些对象有可能会溢出,然后我们打开OQL窗口

 

执行如下OQL语句

 

也就是说这个是null,但是仍然有强引用存在,gc的时候是不能回收的,这样就会出现内存的溢出问题

 

不懂就按F1,关于OQL有详细介绍,

或进官网  mat Querying Heap Objects:http://help.eclipse.org/indigo/index.jsp?topic=%2Forg.eclipse.mat.ui.help%2Ftasks%2Fqueryingheapobjects.html

一步一个脚印,方便自己复习,该出手时就出手,有错误,一定要指正,非常感谢,共同进步!

 

http://www.cnblogs.com/o-andy-o/archive/2013/06/11/3132316.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值