JVM的内存模型
阅读须知:本文只是日常记录,博主并未深究。
内存模型
JVM的模型可大致分为:程序计数器、Java虚拟机栈、本地方法栈、Java堆 、方法区。
线程私有的部分有:黄底部分
线程共享的区域有:加粗部分
至于原因嘛,看了各个部分的作用以及解释就明白了。
程序计数器(Program Counter Register)
学过OS的应该都知道,一个处理器在多线程的环境中,需要频繁的切换线程,来达到并发的效果。而程序计数器就是为了在切换后能记录切换前程序执行的位置,以便线程切换后能够恢复到正确的执行位置。
Java虚拟机栈 (Java Virtual Machine Stack)
经常有人会把Java的内存区域笼统地划分为栈(Stack)和堆(Heap),这种划分方式直接继承了传统的C、C++内存布局,但并不准确。这里的栈通常指的是Java虚拟机栈。
Java虚拟机栈作用:顾名思义,Java虚拟机栈是一个栈,为Java方法服务。每个方法被调用到执行都对应着栈帧在虚拟机中入栈到出栈的过程。
本地方法栈(Native Method Stacks)
与上面的Java虚拟机栈的作用非常类似,不同的是后者为虚拟机使用本地方法服务。JVM队本地方法栈中方法的语言、数据结构并未做强制规定,也就意味着其他语言在实现本地方法栈后照样可以是使用JVM。
Java堆(Java Heap)
用于存放几乎所有的对象实例。《Java虚拟机规范》中的描述是:“所有的对象实例及数组都应当在堆上分配。” 但随着即时编译技术的发展,尤其是逃逸分析技术日渐强大,栈上分配、标量替换手段已经导致一些微妙的变化的发生,这句话也就不那么绝对了。
方法区(Method Area)
此块区域用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器后编译的代码缓存等数据。