Java教程

JVM内存模型

本文主要是介绍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会将失去引用的对象进行垃圾回收,具体回收细节,我将在下一篇博客讲到

 

这篇关于JVM内存模型的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!