这是一篇关于JVM的学习记录
文章目录
前言
此次文章主要是关于JVM的定义及运行原理的一些学习记录。
一、JVM到底是什么?
JVM其实本质上算是一台虚拟机,能够让Java程序独立于操作系统运行,实现一次编译多处运行,因此Java程序才可以在不同的操作系统上运行(例如:Linux,Windows)。
二、JVM存在于JRE中
JVM依托于JRE中,在我们在Windows中下载安装jdk已经包含有JRE,通俗上讲JVM就是学习安装Linux时的Linux而JRE就是VMWare,我们需要有JRE来为JVM搭建好虚拟机环境。
三、JVM的结构
JVM主要是分为程序计数器(Program Counter),Java堆(Heap),Java虚拟机栈(Stack),本地方法栈(Native Stack),方法区(Method Area)
1.程序计数器(Program Counter)
程序计数器(Program Counter 以下简称“PC”)用于指示,跳转下一条需要执行的命令。
JVM多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的,每个线程就具有一个PC并且互相不存在影响,每个PC所占的内存就是私有内存。
2.Java堆(Heap)
Java堆是被所有线程共享的一块区域,在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存,其也是垃圾收集器管理的主要区域。
3.Java虚拟机栈(Stack,Java Virtual Mechine Stacks)
同PC一样(从工作流程图里我们可以看到,实际上,PC也是存在于JVM Stack上的),也是线程私有的,生命周期与线程相同。虚拟机栈描述Java方法执行的内存模型,每个方法被执行时都会创建一个栈帧(Stack Frame),栈帧会利用局部变量数组存储局部变量(Local Variables),操作栈(Operand Stack),方法出口(Return Value),动态连接(Current Class Constant Pool Reference)等信息。
个人理解:其实主要储存的就是变量,JVM会调用这一部分进行局部变量的空间分配
4.本地方法栈(Native Stack)
其为native方法服务,在JVM中没对其实现做具体规定,native方法就是调用非代码的接口。
5.方法区(Method Area)
方法区和Java堆类似,也属于各线程共享的内存区域。用于存储已被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码数据等,它属于非堆区(Non Heap)。
总结
第一篇笔记已经大功完成,还是有很多不熟悉的地方要在接下来的学习中慢慢深入。
本次文章主要参阅了下面链接里的文章作者写的非常详细。
https://editor.csdn.net/md?not_checkout=1&articleId=123548001