如何在JVM内存中确认class文件的常量池?

常量池的描述在java虚拟机规范的4.4节(jvms8)中有很详细的描述,这里就不再描述常量池是什么?其在class文件中是如何表示的?。今天我们主要是看看 hotspotVM 中,如何在内存中查看常量池内容。

我们以java.io.FileInputStream.java为例看看它的在hotspotVM中的常量池内容是什么。

首先我们通过javap 看看class文件中常量池的表示:

然后使用HSDB来看看hotspotVM中的相关内容

 

通过HSDB 我们在hotspotVM内存中查看了前6个常量池的内容和javap的结果是一样的。

为什么我们能在0x000000001c181540为起始地址的数组中找到常量池内容?这取决于hotspotVM的ConstantPool实现。在hotspotVM中每解析一个常量都会将该常量放进常量池,

-----------------------------------未完待续------------------------------------------

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值