Java学习笔记——JVM

这是一篇关于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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值