ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JVM 学习笔记(三)

2020-07-08 23:36:15  阅读:205  来源: 互联网

标签:jvm Eden 对象 笔记 学习 GC 内存 JVM heap


一:使用jvisualvm工具查看堆内存

visualgc插件下载链接 : https://visualvm.github.io/pluginscenters.html --->选择对应版本链接--->Tools--->Visual GC   首先我们启动本地工程,不停地往内存中添加对象,代码如下:
@RestController
public class HeapController {
    List<Person> list=new ArrayList<Person>();
    @GetMapping("/heap")
    public String heap() throws Exception{
        while(true){
            list.add(new Person());
            Thread.sleep(1);
        }
    }
}

使用的是springBoot的工程,启动后访问:localhost:8080/heap

这样是程序不停地往内存中添加对象

我们在jvisualvm工具中找到当前进程,如图:

 

 

双击进入如下界面:

 

 这边可以非常直观地看出jvm中堆的内存分布情况,正好验证了我之前在(二)中的文章所写的那样:

Survivor区详解:

  由图解可以看出,Survivor区分为两块S0和S1,也可以叫做From和To。在同一个时间点上,S0和S1只能有一个区有数据,另外一个是空的。

  接着上面的GC来说,比如一开始只有Eden区和From中有对象,To中是空的。此时进行一次GC操作,From区中对象的年龄就会+1,我们知道Eden区中所有存活的对象会被复制到To区,From区中还能存活的对象会有两个去处。若对象年龄达到之前设置好的年龄阈值,此时对象会被移动到Old区,如果Eden区和From区没有达到阈值的 对象会被复制到To区。 此时Eden区和From区已经被清空(被GC的对象肯定没了,没有被GC的对象都有了各自的去处)。这时候From和To交换角色,之前的From变成了To,之前的To变成了From。也就是说无论如何都要保证名为To的Survivor区域是空的。Minor GC会一直重复这样的过程,知道To区被填满,然后会将所有对象复制到老年代中。

 

 二:堆内存溢出情况

  我们可以适当调节内存的大小,来展示jvm内存溢出的现象,如图,可以在idea中设置jvm堆内存的最大和最小参数:

 

 运行后访问localhost:9090/heap,等待内存溢出的现象:

 

 

 

 

 

 

 在该工具中可以很明显看出jvm的堆内存已经满了,果然在idea也报了OOM:

 

 

小结

  通过jvisualvm工具,我们可以很直观地看出项目在运行时jvm中堆内存的变化,这个工具还是比较强大的,大家有时间可以试试,今天就分享到这里,还有方法区内存

和虚拟机栈内存的变化会在下个文章中分析

 

标签:jvm,Eden,对象,笔记,学习,GC,内存,JVM,heap
来源: https://www.cnblogs.com/talkingcat/p/13269989.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有