目录
1、程序计数器(内存中最小的一块,里面保存了当前线程下一条执行的指令的地址)
JVM的内存区域划分分为四个区域:程序计数器,栈,堆,方法区(现在也叫元数据区)。
1、程序计数器(内存中最小的一块,里面保存了当前线程下一条执行的指令的地址)
每个线程只有一个程序计数器,所以每个程序计数器是线程私有的。操作系统是以线程为单位调度的,所以每个线程都需要记录自己当前执行到哪一步了,以便后续再次调用。
2、栈(保存局部变量和方法调用的信息)
栈也是线程私有的,在我们调用方法的时候,每调用一个方法,该方法就会进入栈中,当该方法执行完毕的时候就会从栈中移除。
比如说现在要在main方法中调用A方法,在A方法中再调用B方法:
但是,如果我们不停的调用方法,就会导致栈满,这样就会出现栈满了的报错信息。这种现象尤其是在递归的时候容易出现。
每一个线程都有一个栈,每个栈都是线程私有的。
栈中还有个比较特殊的叫做本地方法栈,这个栈是存放native方法的,比如hashCode(),同样是线程私有的。
3、堆 (成员变量和new出来的对象都在堆上)
堆是属于线程共享的,只有一个堆的存在。成员变量和new出来的对象都在堆上,所以堆也是内存中最大的一块空间。需要注意的是,new出来的对象是在堆上,但是对new出来的对象的引用却是在栈上面的。
4、方法区(存储常量,静态变量,类对象等等)
方法区也是线程共享的,方法区存放了类对象,以及该类的静态属性,运行时常量池(JDK8之前。JDK8移到堆中了),类属性等等 。
运行时常量池中包含字面量和符号引用
字面量 : 字符串、final常量、基本数据类型的值。
符号引用 : 类和结构的完全限定名、字段的名称和描述符、方法的名称和描述符。