JVM:
JVM由类装载子系统、运行时数据区、执行引擎、垃圾收集四部分组成。
1、类的加载
类的加载是将类的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,
然后在堆区创建一个java.lang.Class对象,用来封装类在方法区内的数据结构。
2、运行时数据区
栈:运行
堆:存储
2.1、方法区
各线程共享的内存区域,用于存储已被JVM加载的类信息、常量、静态变量、运行时常量池等数据。
2.2、java堆
在JVM启动时创建,这块区域是JVM中最大的,用于存储应用的对象和数组,也是GC主要的回收区,一个JVM实例只存在一个堆内存,对内存的大小是可以调节的。类加载器读取了类文件后,需要把类、方法、常量、变量、放到堆内存中,以方便执行器执行。
2.3、java栈
在线程创建时创建,线程私有。生命周期跟随线程的生命周期,线程结束栈内存也释放,不存在垃圾回收问题。基本类型的变量和对象的引用变量都是在函数的栈内存中分配。
2.4、程序计数器
程序计数器是一块非常小的内存空间,每个线程都有,线程私有。
可以看作是当前线程所执行的字节码的行号指示器,指向方法区中的方法字节码,由执行引擎读取下一条指令。
2.5、运行时常量池
方法区的一部分,用于存放编译器生成的各种字面量和符号引用,会在类加载后存放到方法区的运行时常量池中。
3、垃圾收集器
回收内存中不再使用的对象。
3.1、基本步骤
查找内存中不再使用的对象,
释放这些对象占用的内存。
3.2、判断策略
1.引用计数算法
给对象添加一个引用计数器,每当有一个引用它是,计数器值就加1;
引用时效,就减1。
任何时刻计数器都为0的对象就是不可能再被使用的对象,
但是很难解决对象之间相互玄幻引用的问题。
2.根搜索算法
根搜索算法是通过一系列名为GC Roots的对象作为起始点,从这些节点开始向下搜索。
搜索所走过的路径称为引用链,当一个对象到GC Roots没有任何引用链相连时,则证明此对象是不可用的。
3.3、GC收集算法
1.标记-清除算法
标记-清除孙发采用从根集合进行扫描,首先标记出所有需要回收的对象(根搜索算法),标记完成后统一回收掉所有被标记的对象。
2.复制算法
复制算法是将可用内存按容量划分为大小相等的两块,每次只用其中一块,当这一块的内存用完,就将还存活的对象复制到另外一块上面,然后把已使用过的内存空间一次清理掉。
3.标记-整理算法
标记整理算法的标记过程和标记清除算法相同,但后续步骤不再对可回收对象直接清理,而是让所有存活的对象都向一端移动,然后清理掉端边界以外的内存。
4.分代收集算法
目前大部分JVM的垃圾收集器采用的算法,根据对象存活的生命周几将内存划分为若干个不同的区域。