前面我们讲的虚拟机栈,本地方法栈,程序计数器,他们有共同特点,他们都是线程私有的。从现在开始讲的堆和方法区可以看成是线程共享的区。
5.1 定义
Heap 堆
-
通过new关键字创建的对象都会使用堆的内存
特点
-
他是线程共享的,堆中的对象都需要考虑线程安全的问题
-
有垃圾回收机制,堆中不再被引用的对象就会被回收释放内存。
5.2 堆内存溢出问题
思考:堆中不是会垃圾回收吗?怎么还会存在内存溢出?
-
对象被回收条件是没人使用他,如果我不断产生对象并且一直使用,那内存是不是就顶不住了。
可以用-Xms来修改堆内存大小。
5.3 堆内存诊断
1:jps工具
-
查看当前系统又哪些java进程
2:jmap工具 (jmap -heap 进程id)
-
查看堆内存情况(只能查看某一时刻的,如果要看连续的得用下面一个)
3:jconsole工具
-
图形化的,多功能的,可以连续监测
我们的新生的堆内存占用在这里看
案例:垃圾回收以后,内存占用仍然很高
另外一个更好用的工具jvisualvm