jre=JVM+Java类库
jdk=jre+Java运行开发调试工具
jvm的运行时数据区:
线程共享的部分:方法区,堆内存,运行时常量池(开启多个线程以后,共享的部分)
线程私有区:本地方法区,虚拟机内存,程序计数器。
java的垃圾回收机制:
该算法的提出是为了克服句柄的开销和解决堆碎片的垃圾回收。它将内存按容量分为大小相等的两块,每次只使用其中的一块(对象面),当这一块的内存用完了,就将还存活着的对象复制到另外一块内存上面(空闲面),然后再把已使用过的内存空间一次清理掉。
复制算法比较适合于新生代(短生存期的对象),在老年代(长生存期的对象)中,对象存活率比较高,如果执行较多的复制操作,效率将会变低,所以老年代一般会选用其他算法,如标记—整理算法。一种典型的基于Coping算法的垃圾回收是stop-and-copy算法,它将堆分成对象区和空闲区,在对象区与空闲区的切换过程中,程序暂停执行。
优点:(1)标记阶段和复制阶段可以同时进行。(2)每次只对一块内存进行回收,运行高效。(3)只需移动栈顶指针,按顺序分配内存即可,实现简单。(4)内存回收时不用考虑内存碎片的出现(得活动对象所占的内存空间之间没有空闲间隔)。
缺点:需要一块能容纳下所有存活对象的额外的内存空间。因此,可一次性分配的最大内存缩小了一半。
内存溢出问题:oom
内存泄漏和内存溢出的关系:
什么是内存泄漏:
JVM对象头里面的数据:
运行时数据:重点:mark word 运行时数据。
类型指针:指向创建该对象的类
如果为对象数组,会有一个记录数组长度的数据
jvm的垃圾回收器:默认的是并行收集器
原因是:多线程的,考虑吞吐的话也是最优的
简单介绍一下并行垃圾收集的作用:
目的是:缩短垃圾回收的时间
方式:利用cpu的多核,开启多个线程,多个GC worker来进行多线程的操作。