深入理解Java虚拟机问题

走近Java

JDK、JRE与JVM

JDK全称为Java SE Development Kit(Java开发工具),提供了编译和运行Java程序所需的各种资源和工具,包括:JRE+java开发工具。
JRE全称为Java runtime environment(Java运行环境),包括:虚拟机+java的核心类库。
JVM是运行Java程序的核心虚拟机。
深入理解Java虚拟机问题_第1张图片
内存溢出的问题及解决
深入理解Java虚拟机问题_第2张图片
如上面代码所示,不断向堆内存中加入对象,会造成异常:Exception in thread “main” java.lang.OutOfMemoryError: Java heap space,运行过程中计算机内存不断上升直到报错。
深入理解Java虚拟机问题_第3张图片
可以通过添加参数-XX:+HeapDumpOnOutOfMemoryError -Xms20m -Xmx20m 来输出堆存储快照,在项目目录下出现名为java_pid24672.hprof的文件。如果想解析该文件,需要下载Eclipse提供的解析器MemoryAnalyzer,下载地址为:https://www.eclipse.org/mat/downloads.php 通过该软件打开java_pid24672.hprof文件可以看到内存的实际应用情况,判断内存溢出原因。
深入理解Java虚拟机问题_第4张图片
jvm可视化监控工具
jdk自带可视化监控工具,在目录C:\Program Files\Java\jdk1.8.0_171\bin下,直接在命令行输入jconsole即可运行,源代码在tools.jar包中。

运行如下代码,不断向集合中加入元素,堆内存不断增大:
深入理解Java虚拟机问题_第5张图片
深入理解Java虚拟机问题_第6张图片
同时可以看出Eden区呈折线变化,这是由于垃圾回收机制的回收作用。
深入理解Java虚拟机问题_第7张图片

你可能感兴趣的:(Java,jvm,java,linux,spring,后端)