仅作个人学习笔记!
class文件——>ClassLoader SubSystem——>running data area ——>GC
本地方法栈、本地方法接口、本地方法库
虚拟机栈:方法1(栈帧1)、方法2(栈帧2)
方法区和堆是进程私有(95%是在堆区,5%是在方法区)
程序技术器,虚拟机栈,本地方法栈是线程私有
一个JVM实例对应一个运行时数据区(一个Runtime对象)
线程:
线程是一个程序的运行单元,一个进程有多个线程,
每一个线程与操作系统的本地线程直接映射,当一个java线程准备好后,此时一个操作系统的本地线程也同时创建,java线程执行终止后,本地线程也会回收。
操作系统负责所有线程的安排调度到任何一个可用的CPU上,一旦本地线程初始化成功,它就会调用java线程中的run()方法。
守护线程、普通线程
PCR
程序计数器(Program Counter Register,PCR,程序计数寄存器)(PC寄存器)
行号指示器,作用:存储指向下一条指令的地址,也即将要执行的指令代码,由执行引擎读取下一条指令。很小的一块空间,线程私有,PCR是程序控制流的指示器,
GC、OOM
为什么要使用PCR记录当前线程的执行地址呢?
因为CPU需要不断切换各个线程
为什么PCR线程私有?
并行?并发?
归根结底PCR是记录实际线程执行到的地方,每个线程必须使用自己的PCR。
CPU时间片:
CPU分配给各个程序的时间,每个线程被分配给一个时间片,
并行(多线程同时执行)对应串行(多线程一直切换);
并发(垃圾回收线程和用户线程,一个核多频切换,看似是在同时执行,不会出现StopTheWorld)
虚拟机栈(Java Virtual Machine Stack)
背景:由于跨平台的设计,java的指令都是根据栈来设计的。不同平台CPU架构不同,所以不能设计为基于寄存器的。
优点是跨平台,指令集小,编译器容易实现,缺点是性能下降,实现同样的功能需要更多的指令。
栈是运行时的单位,堆是存储的单位。
栈解决程序的运行问题,即程序如何执行,或者说如何处理数据,堆解决的是数据存储的问题,即数据怎么放,放在哪儿。
栈存放局部变量,基本数据类型和引用数据类型的引用(地址)
每个线程在创建时都会创建一个虚拟机栈,其内部保存一个个的栈帧(Stack Frame),对应着一次次的Java方法调用。虚拟机栈是线程私有的,虚拟机栈的作用是主管Java程序的运行,它保存方法的局部变量、部分结果,并参与方法的调用和返回。
局部变量 成员变量
基本数据类型 引用数据类型(类、数组、接口)
栈是一种快捷有效的分配存储方式,访问速度仅次于PCR。
JVM对于Java栈的操作只有两个:每个方法执行,伴随着进栈(入栈、出栈)
执行结束后的出栈工作
对于栈来说不存在垃圾回收问题。
GC,OOM不存在
开发中遇到的异常有哪些?
内存溢出,内存泄漏,StackOverflowError
Java栈的大小是动态的或者是动态不变的。
设置栈内存的大小,可以使用参数-Xss命令,默认都是1M
-Xss1m
int count = 1;11420默认大小,
设置栈的大小-Xss256k
栈的存储单位:
每个线程有自己的栈,栈中的数据都是以栈帧(Stack Frame)的格式存在。在这个线程上正在执行的每个方法都各自对应一个栈帧(Stack Frame)。栈帧是一个内存区域,是一个数据集,维系者方法执行过程中的各种数据信息。
复习:OOP的基本概念:类、对象
类中基本结构:filed(属性、字段、域)、method
当前栈帧、当前方法、当前类