-
pc regsiter表示注册表,每一个线程都有自己的regsiter,并且在任意时间一个线程都只有一个方法在执行,计数器会存储当前线程正在执行的方法的JVM指令地址
-
jvm-Virtual Machine stack:一个Java虚拟机栈,每一个虚拟机进程只有一个虚拟机栈,并且每一个虚拟机栈存放一个frame,每次方法调用均会创建一个对应的Frame,方法执行完毕或者异常终止,Frame被销毁。一个方法A调用另一个方法B时,A的frame停止,新的frame被创建赋予B,执行完毕后,把计算结果传递给A,A继续执行。一个JVM栈存储本地变量以及执行部分方法的返回值。
其中frame中分为4部分:
1.Local Variables:基本数据类型、引用数据类型、方法返回地址
2.Operand Stack:通过LIFO方式操作数据
3.Dynamic Linking:转换符号引用到直接引用,例如String str=“China”;其中str属于符号引用,"China"在字符串常量池直接引用
4.Method Invocation Completion
-
JVM-heap是虚拟机中的堆,是一个被虚拟机共享的地方,用于存储由类产生的对象和数组区域,在虚拟机启动时就会创建,heap区域会被gc回收,如果heap不足,会抛出OutOfMemoeryError异常
-
JVM-Method Area:方法区,被所有的虚拟机共享,但是不仅仅存放方法,会存放常量池,类的属性,方法数据,方法和构造方法的代码等,在逻辑上也属于heap
-
jvm-Run-Time Constant Pool:JVM 为每个类型都维护了一个常量池,这是一种运行时数据结构,它可以满足一般编程一语言常量表的功能。每个运行时常量池都是从方法区分配的。当 JVM 创建类或接口时,会为其创建它的运行时常量池。
-
JVM-native method stack:这一部分由其他语言实现