对象的创建 jvm 对象

过程

   1.给对象分配内存

   2.线程安全性问题(

       1.线程同步加锁 (缺点:执行期望值太低)2.本地线程分配缓存,在内存中为每个线程分配一块内存,作用就是每个线程操作不同区域)

   3.初始化对象

   4.执行构造方法

new 类名->根据new的参数在常量池中定位一个类的符号引用->如果没有找到符号的引用,说明类没有被加载,这进行类的加载,解析和初始化->虚拟机为对象分配内存在堆中->将分配的内存初始化为零值(不包括对象头)->调用对象的init方法。

为对象分配内存的策略:

java堆是否规整决定使用下面那种方式

    指针碰撞(垃圾回收的过程中压缩整理,)

    空闲类表(垃圾回收器没有这种功能)

对象的结构

  对象头(Header):包含两部分,第一部分用于存储对象自身的运行时数据,如哈希码、GC 分代年龄(垃圾回收标记清除,复制,标记整理,分代回收依赖于前面算法)、锁状态标志、线程持有的锁、偏向线程 ID、偏向时间戳等,32 位虚拟机占 32 bit,64 位虚拟机占 64 bit。官方称为 ‘Mark Word’。第二部分是类型指针,即对象指向它的类的元数据指针,虚拟机通过这个指针确定这个对象是哪个类的实例。另外,如果是 Java 数组,对象头中还必须有一块用于记录数组长度的数据,因为普通对象可以通过 Java 对象元数据确定大小,而数组对象不可以。

Synchronizedä¸ä¸ç§éæ_第1å¼ å¾ç

实例数据(Instance Data):程序代码中所定义的各种类型的字段内容(包含父类继承下来的和子类中定义的)对象的有效信息相同宽度的字段分配一起虚拟机分配策略。

对齐填充(Padding):不是必然需要,主要是占位,保证对象大小是某个字节的整数倍。

对象访问定位:

使用句柄的最大好处是 reference 中存储的是稳定的句柄地址,在对象移动(GC)是只改变实例数据指针地址,reference 自身不需要修改。直接指针访问的最大好处是速度快,节省了一次指针定位的时间开销。如果是对象频繁 GC 那么句柄方法好,如果是对象频繁访问则直接指针访问好。

  使用句柄:指向堆中的句柄池,保存实例对象的(为啥不直接用指针,地址不用修改)

(两个数据:到对象实例对象实例数据的指针,到对象类型数据的指针)

  直接指针:
 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值