JVM-001-环境搭建及一个小例子
2017-11-22 本文已影响1人
53b3f4658edc
安装JDK
请查看这篇文章:认识JDK并配置path环境变量
一个内存泄漏分析的小例子
编写内存泄漏的代码
package top.itcourse.oom;
import java.util.ArrayList;
public class TestOOM {
public static void main(String[] args) {
List<Test> list = new ArrayList<>();
while (true) {
list.add(new Test());
}
}
}
class Test {
private String[] names = new String[1000*1000*1000];
}
运行上面的程序,打开jconsole
data:image/s3,"s3://crabby-images/c93fc/c93fc9c1f59469c9ef7e9dd487d47e2d19a335bb" alt=""
观测内存折线图
data:image/s3,"s3://crabby-images/3e36e/3e36e7bc3a91754957505f6092cf5aefb1713f57" alt=""
抓取内存快照
在运行的配置中输入如下参数:-XX:+HeapDumpOnOutOfMemoryError -Xms20m -Xmx20m
data:image/s3,"s3://crabby-images/93659/936590762036b4bb760c88dd866e6a8a98171973" alt=""
安装Eclipse Memory Analyzer
http://www.eclipse.org/mat/downloads.php
再次运行程序,并打开.hprof文件
data:image/s3,"s3://crabby-images/69b9b/69b9b93e2ae8a07c21c13c13e37ad39f86587dc2" alt=""
data:image/s3,"s3://crabby-images/93398/933985fdb2a3c274d52dd7bd7c8bf75604ec0c98" alt=""
其它
关注下方微信公众号,
回复:
JVM.code
-
欢迎加入交流群:451826376
-
更多信息:www.itcourse.top