今天看了java虚拟机这本书中关于内存区域的这个部分,总是希望清晰一些,包括目前还有些疑惑的地方,写此记录。
程序计数器:当前线程所执行的字节码的行号指示器;
虚拟机栈:Java虚拟机栈是线程私有的,生命周期与线程相同。虚拟机栈描述的是java方法执行内存模型:每个方法被执行的时候会创建一个栈帧用于存储局部变量表、操作数栈,动态链接,方法出口等信息;每个方法执行的过程就是一个栈帧在虚拟机中从入栈到出栈的过程;
本地方法栈:虚拟机栈为虚拟机执行java方法服务;本地方法栈为虚拟机执行native方法服务;与虚拟机栈作用相似;
堆:虚拟机启动时创建,此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存;垃圾收集器主要工作区域,所以也被称作“GC堆”。
方法区:存储已被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码等数据;
包含“运行时常量池”;运行时常量池:用于存放编译期生成的各种字面量和符号引用;
直接内存:不是虚拟机运行时数据区的一部分,也不是java虚拟机规范中定义的内存区域;在jdk1.4中加入了NIO(new input/output)类,引入一种基于通道与缓冲区的I/O方式,它可以使用native函数库直接分配堆外内存,然后通过一个存储在java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作。为了避免java堆与native堆来回复制数据;
总结:我们知道了局部变量存放于虚拟机栈中局部变量表,方法执行过程就是栈帧在虚拟机中的入栈与出栈,堆主要干的事情就是存放对象实例,GC的工作也在这里,了解了直接内存;
就是一个类的成员变量到底如何存储过程?
网路搜索未找到合理的解答。
直接内存:不是虚拟机运行时数据区的一部分,也不是java虚拟机规范中定义的内存区域;在jdk1.4中加入了NIO(new input/output)类,引入一种基于通道与缓冲区的I/O方式,它可以使用native函数库直接分配堆外内存,然后通过一个存储在java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作。为了避免java堆与native堆来回复制数据;
总结:我们知道了局部变量存放于虚拟机栈中局部变量表,方法执行过程就是栈帧在虚拟机中的入栈与出栈,堆主要干的事情就是存放对象实例,GC的工作也在这里,了解了直接内存;
就是一个类的成员变量到底如何存储过程?
网路搜索未找到合理的解答。