JVM笔记

JVM笔记,第1张

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被别的线程抢走后,回来时可以继续当时的进度.

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5695641.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存