欢迎分享,转载请注明来源:内存溢出
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)
打赏
微信扫一扫
支付宝扫一扫
JSTL的使用
上一篇
2022-12-17
java2实用教程第六版习题答案
下一篇
2022-12-17
评论列表(0条)