堆内存诊断(jps,jmap,jconsole,jvisualvm查看)

Heap 堆

  • 通过 new 关键字,创建对象都会使用堆内存

特点

  • 它是线程共享的,堆中对象都需要考虑线程安全的问题
  • 有垃圾回收机制

堆内存演示过程(jps + jmap查看)

1、代码
public class HeapDemo {
    public static void main(String[] args) throws InterruptedException {
        System.out.println("1...");
        Thread.sleep(30000);
        byte[] array = new byte[1024 * 1024 * 10]; // 10 Mb
        System.out.println("2...");
        Thread.sleep(20000);
        array = null;
        System.gc();
        System.out.println("3...");
        Thread.sleep(1000000L);
    }
}
2、运行代码,打开终端,查看进程
jps

在这里插入图片描述

3、执行命令,查看内存使用情况
jmap -heap 16040

在这里插入图片描述

代码执行到1…输出时,执行一次jmap -heap命令,
在这里插入图片描述

代码执行到2…输出时,执行一次jmap -heap命令,
在这里插入图片描述

输出3…时再执行一次jmap -heap命令
在这里插入图片描述

4、刚运行,输出1时,对象没创建,堆内存使用5.7M

在这里插入图片描述

5、输出2时,对象已创建,堆内存15.7M

在这里插入图片描述

6、垃圾回收后,堆内存0.9M

在这里插入图片描述

jconsole工具查看

执行代码
执行命令
jconsole
jconsole工具连接

在这里插入图片描述

内存使用详情

在这里插入图片描述

jvisualvm工具(功能多)

输入命令

jvisualvm

在这里插入图片描述

查看
在这里插入图片描述

结束!!!!!


										要往前走,就得先忘掉过去。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值