大话Java对象在虚拟机中是什么样子?

大话Java对象在虚拟机中是什么样子?

作者:Danny姜 2020-04-09 11:00:20

云计算

虚拟化 JVM本身是用C艹实现的,一个Java对象在是如何映射到C层的对象呢?最简单的做法是为每个Java类生成一个结构相同c++类与之对应。

 [[321609]]

程序员最不缺的就是对象,每天都会给自己创建成百上千的对象。可是你真的了解你的对象吗?比如以下类代码:

 

上面代码,在main方法中通过 new 关键字创建了Foo类的实例对象,并且通过引用 foo 指向这个对象。那么它们以及静态变量staticValue和实例变量localValue都是被保存在内存中什么位置,以及它们是以何种方式存在的呢?

Java OOP-Klass 模型

JVM本身是用C艹实现的,一个Java对象在是如何映射到C层的对象呢?

最简单的做法是为每个Java类生成一个结构相同c++类与之对应。

但HotSpot JVM并没有这么做,而是设计了一个OOP-Klass Model。这里的 OOP 指的是 Ordinary Object Pointer (普通对象指针),它用来表示对象的实例信息。而 Klass 则包含元数据和方法信息,用来描述Java类。

之所以采用这个模型是因为HotSopt JVM的设计者不想让每个对象中都含有一个vtable(虚函数表),所以就把对象模型拆成klass和oop,其中oop中不含有任何虚函数,而Klass就含有虚函数表,可以进行method dispatch。

OOP-Klass模型 分为OOP框架和Klass框架

Klass 包含元数据和方法信息,用来描述Java类。

Klass是用来表示class的元数据,包括常量池、字段、方法、类名、父类等。Klass 对象中含有虚函数表vtbl 以及父类虚函数表klass_vtbl, 因此可以根据java对象的实例类型方法的分发。

JVM 在加载class字节码文件时,会在方法区创建Klass对象,其中 instanceKlass 可以认为是 java.lang.Class 的VM级别的表示,但它们并不等价,其结构如下图所示,

 

上图中的所有全局变量会在class字节码解析阶段完成赋值,主要是将常量池中的符号引用转换为直接引用,即运行时实际内存地址。

OOP 指的是普通对象指针,用来表示对象的实例信息

所有的 OOP 类的共同基类为 oopDesc 类。它的结构如下:

 

当在Java中使用 new guan’jian创建一个对象时,就会在JVM中创建一个 instanceOopDesc 实例对象。Foo中的localValue就是保存在这个对象当中。

我们经常说Java对象在内存中的布局分为:对象头、实例数据、对其填充。其实这3部分就是对应上面图中的 oopDesc 对象。

_mark和_metadata 一起组成了对象头部分:

  • Mark Word:instanceOopDesc 中的 _mark 成员,允许压缩。它用于存储对象的运行时记录信息,如哈希值、GC 分代年龄(Age)、锁状态标志(偏向锁、轻量级锁、重量级锁)、线程持有的锁、偏向线程 ID、偏向时间戳等。
  • 元数据指针:instanceOopDesc 中的 _metadata 成员,它是联合体,可以表示未压缩的 Klass 指针(_klass)和压缩的 Klass 指针。对应的 klass 指针指向一个存储类的元数据的 Klass 对象。

在对象头之后,JVM会继续填充Java对象中的具体实例数据,比如Foo中的localValue。

Foo具体分析

接下来重新回到文章开头的实例代码,Foo.java中包含两个变量staticValue和localValue,但是只有staticValue会在类加载阶段由JVM分配内存并初始化默认值,因此当代码执行到第7行时,内存中只会在方法区创建Klass对象,用来描述Foo信息以及staticValue值,如下图所示:

 

可以看出,此时堆内存中并没有创建Foo对应的instanceOopDesc实例对象。

当代码执行到第9行,调用 new 创建Foo时,JVM 就会创建一个 instanceOopDesc 对象表示这个对象的实例,然后进行 Mark Word 的填充,将元数据指针指向刚才在方法区创建的 Klass 对象,并填充实例变量。并且因为方法是在main方法中执行,所有foo指针会被保存在虚拟机栈中,并指向创建的 instanceOopDesc 对象。具体过程如下:

 

 

 

 

可以看出 localValue 是被保存在堆中的。

综上所述:

  • foo是一个局部方法中的引用,被保存在虚拟机栈中
  • staticValue静态变量在类加载阶段被保存在方法区,并被赋值
  • localValue 实例变量是在创建对象时才会被创建并赋值
  • 一个Java对象在JVM中被分成2部分:OOP和Klass。其中OOP对象保存对象里实例数据,Klass用来描述类相关信息以及保存静态变量。

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/272249.html<

(0)
运维的头像运维
上一篇2025-05-08 16:00
下一篇 2025-05-08 16:02

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注