JVM 基础
运行时数据区–把内存虚拟化
1.线程私有区 (虚拟机栈, 本地方法栈, 程序技术器)
2.线程共享区(方法区->运行时常量池(1.7 永久代, 1.8 元空间), 堆)
3.直接内存
常量池
1.静态常量池: 记录在class文件 constant pool中的常量
2.运行时常量池: class加载中-->符号引用(代码中)转换为直接引用(实际内存地址)
字面量
String a="1111aaaa";
虚拟机栈
1.大小限制 -Xss
2.栈溢出
直接内存(堆外内存) —>没有虚拟化,必须要手动回收,发生问题难以排查
1.不属于运行时内存部分
2.NIO-->DirectByteBuffer
3.Unsafe类的一些操作`
虚拟机栈与栈帧的关系,每个线程分配一个虚拟机栈,默认大小根据系统的不同而不同,一般情况默认1M
栈帧
1.局部变量表 (定义在代码中的8大基础数据类型) this放在该表第0位
2.操作数栈 ->执行引擎的一个工作区
3.动态链接 每个栈帧都保存了 一个 可以指向当前方法所在类的 运行时常量池, 目的是: 当前方法中如果需要调用其他方法的时候,
能够从运行时常量池中找到对应的符号引用, 然后将符号引用转换为直接引用,然后就能直接调用对应方法, 这就是动态链接
4.完成出口(返回地址) 指向方法调用方栈帧的程序计数器位置
使用 javap -c 命令对class文件进行反汇编
指令集内容见:
JVM字节码,指令集 bytecode 操作码https://cloud.tencent.com/developer/article/1333540
一段代码的执行片段
程序计数器的作用:
1.记录当前线程执行到的位置, 确保在多线程时间片轮转下的正确执行
2.程序计数器不会发生OOM
本地方法栈的作用:
1.本地方法是由C/C++来实现-> native方法
2.用于本地方法的处理
3.虚拟机规范