jconsole使用

先看一张图

根据JConsole和任务管理器对比,堆内存大小在250M左右,差不多空跑一个程序用idea启动springboot就是这个大小

项目启动初始类在一万个左右,活动线程50个上下,cpu利用率可以忽略。

idea工具本身占用内存在1.7G,这个貌似有点大,具体的内存使用需要后续学习?

google浏览器1G内存感觉也是逆天了。

内存分析这张图比较重要,每一个含义需要搞清楚

说明:

老年代  PS Old Gen

新生代 PS Eden Space 对象创建存放的区域

新生代 PS Survivor Space 第一次GC之后存放的区域

代码缓存 Code Cache jvm编译和存储本地代码所占用的内存

本地内存也叫元空间 Metaspace 永久代PermGen从JDK8开始被metaspce替代 (jdk8新概念)

类指针压缩空间  Compressed Class Space  (jdk8新概念)

回收的顺序如下

JDK6回收

jDK8回收

 

对metaspace 和 compressed class space做一个专门的解释,看完即懂

先看一张metaspce内存分配图

 

 解释 CL是class loader的简写,从本地加载,然后根据一定的算法把二进制字节码加载到元空间

持久代中存的内容
       1. JVM中类的元数据在Java堆中的存储区域。
       2. Java类对应的HotSpot虚拟机中的内部表示也存储在这里。
       3. 类的层级信息,字段,名字。
       4. 方法的编译信息及字节码。
       5. 变量
       6. 常量池和符号解析
GC是可以对持久代进行垃圾收集的   既然JDK8取消了持久代用元数据替代,那么元数据存储的内容就是持久代中存储的内容

元空间特点

  1. 充分利用了Java语言规范中的好处:类及相关的元数据的生命周期与类加载器的一致。
  2. 每个加载器有专门的存储空间
  3. 只进行线性分配
  4. 不会单独回收某个类
  5. 省掉了GC扫描及压缩的时间
  6. 元空间里的对象的位置是固定的
  7. 如果GC发现某个类加载器不再存活了,会把相关的空间整个回收掉

Compressed Class Space

看图对照解释

JVM中,每个对象都有一个指向它自身类的指针,不过这个指针只是指向具体的实现类,而不是接口或者抽象类。

 64位的JVM  _Mark 占8个字节常量 _klass 指向类的8个字节的指针 

 为了压缩JVM对象中的_klass指针的大小,引入了类指针压缩空间(Compressed Class Pointer Space)。

 从字面上看内存的分析应该是最简单的了

下面线程这个图感觉有点蒙圈

后续再详细分析

类图  加载了一万个

VM概要 对内存的一个补充

MBean也是非常的使用

 

转载于:https://www.cnblogs.com/mutong1228/p/10290906.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值