阅读 53

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

文章分类
后端
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐