【探究JVM二】运行时数据区与对象的实例化

1. 运行时数据区

JVM体系结构中第二大块----运行时数据区Runtime Data Area

不同的JVM对于内存的划分方式和管理机制存在着部分差异,JRockit和 IBM-J9无方法区空间,本文主要探讨HotSpot

运行时数据区内存划分

JVM运行时数据区的内存划分分为五大区域:

  • 程序计数器(PC计数器)

  • 本地方法栈

  • 虚拟机栈

  • 堆区

  • 方法区

Rutime Data Area

JIT编译缓存可以独立划分或者放到方法区中

  • 堆和方法区是线程共享的,它们是依托于进程而创建存在的;

  • 程序计数器、虚拟机栈、本地方法栈是线程私有的,每个线程独占一份

JIT编译缓存属于线程共享数据

执行引擎中 的垃圾回收机制是针对共享数据区的,主要是针对堆区


2. 对象的实例化

创建对象new的操作并不是原子性的:

Object obj = new Object();

对应的字节码指令:

0 new #2 <java/lang/Object>
3 dup
4 invokespecial #1 <java/lang/Object.<init>>
7 astore_1

这里,联想到了volatile关键字和DCL单例

3. 对象的内存布局

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVM运行时数据是指在JVM进程运行过程中,用于存储数据的各个域,包括以下几个部分: 1. 程序计数器(Program Counter Register):线程私有的域,用于记录当前线程执行的字节码行号,以便线程在执行过程中能够从正确的位置继续执行。 2. Java虚拟机栈(JVM Stack):线程私有的域,用于存储方法的栈帧(Stack Frame),包括局部变量表(Local Variable Table)、操作数栈(Operand Stack)、动态链接(Dynamic Linking)、方法出口(Return Address)等信息。当一个方法被调用时,JVM会在栈中为该方法分配一个栈帧,方法执行完毕后,栈帧被出栈,JVM继续执行上一个栈帧中的方法。 3. 本地方法栈(Native Method Stack):与Java虚拟机栈类似,用于存储本地方法的栈帧,本地方法是指使用本地语言(如C语言)编写的方法,本地方法栈与Java虚拟机栈的别在于,本地方法栈用于执行本地方法,而Java虚拟机栈用于执行Java方法。 4. 堆(Heap):所有线程共享的域,用于存储对象实例。在JVM启动时,会分配一定大小的堆空间,当堆空间不足时,JVM会自动进行垃圾回收以释放无用的对象,从而维持堆空间的稳定。 5. 方法(Method Area):所有线程共享的域,用于存储类的元数据信息,包括类名称、访问修饰符、常量池、字段描述符、方法描述符等信息。在JDK8及以前的版本中,方法也包括永久代(Permanent Generation),用于存储一些与类加载、字符串常量等相关的信息。在JDK8及以后的版本中,永久代被移除,取而代之的是Metaspace(元空间),用于存储类的元数据信息。 6. 运行时常量池(Runtime Constant Pool):方法的一部分,用于存储编译期生成的各种字面量(Literal)、符号引用(Symbolic Reference)等信息。在方法调用时,JVM会将运行时常量池中的字面量、符号引用等信息加载到操作数栈中,供指令使用。 除了以上几个域外,还有一些其他的域,例如直接内存(Direct Memory),用于存储通过NIO(New IO)库分配的堆外内存。JVM运行时数据域对于Java程序的执行起到了关键的作用,了解这些域有助于我们更好地理解Java程序的执行过程和内存管理机制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值