-
JVM内存模型
JVM内存模型包括 堆 (Heap)、方法区(Method Area)、程序计数器(PC Register)、虚拟机栈(JVM Stacks)、本地方法栈(Native Method Stacks)
一、Java加载过程:
Java Source 需要经过Javac 命令编译为Java class 字节码文件,才能够被Java虚拟机所执行,同样这个字节码文件是一个可以跨平台的,适用于不同平台的机器码。
执行Javac 命令后会创建一个Java虚拟机并创建一个叫 main 的主线程 ,执行主方法,这个线程需要虚拟机栈(JVM Stacks)来分配内存,同样Java创建的其他的一些线程也是同样的。Java方法、局部变量、方法参数等也存放在这里
JVM 见到一个新的类,就会触发类加载机制,由类加载子系统对类进行加载
二、JVM内存结构:
方法区:将类的原始信息(类名、成员变量、类继承关系、方法代码等)读取到内存当中,将此字节码信息,读取到内存中的方法区中
堆:类创建的实例对象存放在堆中
本地方法栈:需要调用操作系统来执行的一些方法例如:hashcode ,调用本地方法接口->本地库(操作系统提供的功能)
注:有的版本的JVM会将虚拟机栈和本地方法栈合二为一,统称虚拟机栈
程序计数器:用来记录当前线程执行到什么地方,即使线程被切换走了,也可以切回来,而不需要重新开始执行
三、执行引擎:
Interpreter 解释器:将Java 字节码翻译成机器码,给操作系统 cpu执行
JITCompiler 即时编译器:对于执行频繁的热联代码 需要经常解释的,用到即时编译器将他缓存起来,少了解释的步骤,执行效率就有了很大的提升。
GC回收:JVM会将失去引用的对象进行垃圾回收,具体回收细节,我将在下一篇博客讲到
来源:https://www.cnblogs.com/gezyx/p/jvm_memory.html