java中jdk、jre、jvm之间的关系可以用一个图来表示

图1
本次主要记录一下jvm的内存区域
1. 程序计数器
- 程序计数器是一块较小的内存空间,它可以看作是当前线程所执行的字节码的行号指示器。在Java虚拟机的概念模型里,字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令,它是程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都需要依赖这个计数器来完成。
- java的线程是通过轮流切换分配处理器实现的,每个线程都有一个独立的程序计数器
- 如果java正在执行Native(本地方法),程序计数器为undefined
2.java虚拟机栈
- 栈桢:虚拟机栈描述的是Java方法执行的线程内存模型:每个方法被执行的时候,Java虚拟机都会同步创建一个栈帧
- 局部变量表:存放了编译期可知的各种Java虚拟机基本数据类型(boolean、byte、char、short、int、float、long、double)、对象引用(reference类型,它并不等同于对象本身,可能是一个指向对象起始地址的引用指针,也可能是指向一个代表对象的句柄或者其他与此对象相关的位置)和returnAddress类型(指向了一条字节码指令的地址)
- java中如果线程请求栈的深度大于虚拟机的所允许时,抛出StackOverFlowError,写递归时经常见到,如果虚拟机可以自动扩展,但无法申请到足够的内存空间时,会出现OutOfMemoryError
3.本地方法栈
- 与虚拟机栈所发挥的作用是非常相似的,其区别只是虚拟机
 栈为虚拟机执行Java方法(也就是字节码)服务,而本地方法栈则是为虚拟机使用到的本地(Native)方法服务。
4.java堆
- 堆是虚拟机管理的最大的一块
- 堆是被所有线程共享的,java中几乎所有的对象都是在这分配内存的(随着技术发展,Java对象实例都分配在堆上也渐渐变得不是那么绝对了)
- 堆是垃圾回收器(gc)所有管理的内存区
- 如果在Java堆中没有内存完成实例分配,并且堆也无法再
 扩展时,Java虚拟机将会抛出OutOfMemoryError异常
5.方法区
- 各线程共享
- 存放虚拟机加载的类信息{
- 类的版本
- 字段
- 方法
- 接口
 
- },常量,静态变量,即时编译器编译后的代码
6.运行时常量池
- 运行时常量池(Runtime Constant Pool)是方法区的一部分。Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池表(Constant Pool Table),用于存放编译期生成的各种字面量与符号引用,这部分内容将在类加载后存放到方法区的运行时常量池中。