public class TestBean {
public int intPro;
public String strPro;
public int intExtend;
public String strExtend;
}
/**
* @param args* @throws Exception
*/
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
unsafe = getUnsafeInstance();
TestBean test=new TestBean();
test.intPro=1111;
test.strPro="22222333";
test.intExtend=3333;
test.strExtend="extend";
marshal(test);
}
@SuppressWarnings({ "deprecation", "restriction" })
public static void marshal(TestBean bean) throws NoSuchFieldException, SecurityException
{
Field[] fields=bean.getClass().getDeclaredFields();
for(int i=0;i<fields.length;i++)
{
Field field =fields[i];
System.out.println(field.getName()+":"+unsafe.objectFieldOffset(field));//打印出字段在对象的偏移地址
}
}
结果输出是:
intPro:12
strPro:20
intExtend:16
strExtend:24
按理说strPro的偏移位置应该是16,而实际上变成了intExtend 偏移位置是16
原因还在研究中,有结论再补充上来
本文通过一个简单的Java示例,深入探讨了对象在内存中的布局方式,特别是针对字符串和整型变量的存储位置进行了详细的分析。文章揭示了一个有趣的现象:字符串成员变量的实际偏移量与预期不符,引发了对Java内存管理机制的进一步思考。
1462

被折叠的 条评论
为什么被折叠?



