运行时数据区域
在运行时数据区内,白色部分的是线程私有的:虚拟机栈、本地方法栈、程序计数器
程序计数器:线程私有,可以看做当前线程所执行的字节码的行号指示器。若线程正在执行一个Java方法,这个计数器记录正在执行的虚拟机字节码指令地址;若正在执行Native方法,则计数器为空。
Java虚拟机栈:线程私有, 生命周期与线程相同。通常所讲的“堆”内存,“栈”内存的“栈”,与虚拟机栈或是说与虚拟机栈中局部变量表是等价的。局部变量表存放了各种基本类型以及引用类型,在编译期就可以完全确定大小。
本地方法栈:线程私有,作用与虚拟机栈相同,只不过执行的是本地方法。
Java堆:线程共享,目的是存放对象实例。通过-Xmx和-Xms可以控制堆是固定大小还是可扩展的。
方法区:线程共享,存储已被虚拟机加载的类信息、常量、静态变量等。
运行时常量池:方法区的一部分。Class文件中除了类的版本、字段、方法、接口等描述信息外,还有一项是常量池(Constant Pool Table),用来存放编译期生成的各种字面量和符号引用。
相关阅读:Java常量池理解与总结
直接内存:NIO中,引入一种基于通道(Channel)与缓冲区(Buffer)的I/O方式,它可以使用Native函数直接分配堆外内存,并且使用Java堆中的DirectByteBuffer对象作为这块内存的引用进行直接操作。
对象的访问定位
- 句柄访问
- 直接指针访问