1.JVM内存划分:
1.程序计数器:当前线程所执行的字节码的行号指示器。
2.本地方法栈:为虚拟机使用的native方法服务。
3.Java虚拟机栈:描述Java方法执行的内存模型,每个方法被执行的时候都会同时
创建一个栈帧用于存储局部变量表、操作栈、动态链接、方法出口等信息。
4.Java堆(heap):被所有线程共享的一块内存区域,在虚拟机启动时创建。所有的对象
实例以及数组都要在堆上分配(存储对象数据,一般的,使用 new 出来的数据都在堆中)。
5.方法区:线程共享的内存区域,存储已被虚拟机加载的类信息、常量、静态变量即时
编译器编译后的代码数据等(这个区域的内存回收目标主要是针对常量池的回收和对类型的卸载).
2.GC(Garbage Collection):垃圾回收器。
Java的自动垃圾回收机制:简单理解为,程序员就不需要再手动的去控制内存的释放。当JVM发觉
内存资源紧张的时候,就会自动地去清理无用对象(没有被引用到的对象)所占用的内存空间。
3.模型图