JVM笔记

JVM 是一个虚拟化的操作系统,类似于 Linux 或者 Windows 的操作系统,只是它架在操作系统上,接收字节码也就是 class ,把字节码翻译成操作系统上的
机器码且进行执行。
过程如下:Java 文件->编译器>字节码->JVM->机器码。
个人理解就相当于在操作系统中嵌套了一个专门用来识别class字节码的操作系统.
我们的操作系统分为CPU+缓存+ 主内存. CPU来计算, 缓存从主内存中提取资源并传给CPU.
JVM 分为 执行引擎+操作数栈+栈堆, 模仿了操作系统的功能.
JVM是跨平台的,我们写的类在别的系统上用对应系统版本的JDk一样可以执行. 同时也是跨语言的,因为JVM只识别class字节码文件, 别的语言也是可以将文件编译成class字节码的,所以它们也可以在JVM上使用. 跨语言奠定了java强大的语言生态圈.
JVM 是一个虚拟化的操作系统,所以除了要虚拟指令之外,最重要的一个事情就是需要虚拟化内存,这个虚拟化内存就是我们马上要讲到的 JVM 的内存区域。

JVM 的内存区域

运行时数据区域
运行时数据区的定义Java 虚拟机在执行 Java 程序的过程中会把它所管理的内存划分为若干个不同的数据区域
JVM 中, JVM 内存主要分为堆、程序计数器、方法区、虚拟机栈和本地方法栈等。
同时按照与线程的关系也可以这么划分区域:
线程私有区域:一个线程拥有单独的一份内存区域。
线程共享区域:被所有线程共享,且只有一份。
了解JVM,知道了JVM是如何反编译class字节码的. 
使用JVM的指令完成反编译: 如 icoust, istore, iload ,iadd等

虚拟机栈

栈的数据结构: 先进后出 (FILO) 的数据结构,
虚拟机栈的作用: JVM 运行过程中存储当前线程运行方法所需的数据,指令、返回地址
虚拟机栈是基于线程的 :哪怕你只有一个 main() 方法,也是以线程的方式运行的。在线程的生命周期中,参与计算的数据会频繁地入栈和出栈,栈的生
命周期是和线程一样的.
栈帧 每个java方法被调用时就会产生一个栈帧,存在虚拟机栈中.
栈帧分为4部分: 
1. 局部变量表  :  用于存放我们的局部变量的, 如果是局部的一些对象,比如我们的 Object 对象,我们只需 要存放它的一个引用地址即可。
2.操作数栈: 执行引擎的一个工作区,
3.动态链接 : 还未讲
4.返回地址 : 还未讲
虚拟机栈这个内存也不是无限大,它有大小限制,默认情况下是 1M
如果我们不断的往虚拟机栈中入栈帧,但是就是不出栈的话,那么这个虚拟机栈就会爆掉
在虚拟机栈还有一个程序计数器, 专门用来记录字节码的行数, 几率当前字节码行走到哪一步了. 当CPU被别的线程抢走后,回来时可以继续当时的进度.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值