面试题

1 new 的时候 向内存申请一块内存空间 此时T对象里面有成员变量 m 此时的m=0 半初始化状态 当执行invokespecial 时会执行该类的构造方法 只有当运行到这里的时候 m=8 a_store 建立关联
volatile 有两大作用 1 线程可见 2 禁止重排 什么叫重排? 当指令看上去是序列执行 但实际上 不是这样的 因为CPU的速度是内存100倍 假如第一条指令需要取内存取数据,第二条则是调用本地 寄存器中的数据 那么CPU在执行第一条取数据的时间内 会执行第二条指令, 所以有可能会先执行第二句指令 然后再执行第一句指令 但是如果这两句指令有关联 那么重排指令的话就会影响最后的结果 如果不想最后的结果发生变化 就需要使用volatile
什么是单例
一个类只能保证new这个类一次
DCL (doyble check lock)


问 这里是否需要加volatile
要 假如第一个线程 先new 在new的时候 构造方法附默认值,此时是半初始化状态 然后成员变量附初始值 最后建立关联 但是在第一条指令结束的时候
第二条指令和第三条指令发生了指令重排 当建立关联之后
(第一个线程new到一半的时候) 第二个线程也new了 但是此时判断instanc 就不为空 那么就会执行返回instance 也就是第一个线程执行到一半
的半初始化状态
然后判断是否为空 结果不为空 直接返回初始值0

1 如果是普通对象 由四块构成 markword 标记头 classPointer 类指针 class 指针 instance Data 实例数据 m padding 对齐 64位对齐 8字节对齐 如果是25位 那么就补到32位 能被8整除 jvm 默认开启压缩类指针 默认大小8字节 压缩后大小4字节 jvm 默认开启oops 普通对象指针 s 默认大小8 字节 压缩后4字节 2 如果是数组有五块构成 markword classpointer length 4字节 instanceData padding

对象头包括markword 8字节 和classpointer 4字节



instance data 4字节 int 类型指针占4字节

String 类型的指针 4字节


这里因为 string 是引用数据类型 指针 才会被压缩 但是int m 是基本数据类型不会被压缩

--------------------------------------------------------------------------以上是classpointer-------------------------------------------------------------------------------
markwork 主要包含什么
锁信息
hashcode
gc 信息



加锁之后


--------------------------------------------------------------------------------------------------------------------------------------------------------------------------


怎么通过new t 找到T 通过句柄池 间接指针 一个指向对象 一个指向t.class GC垃圾回收时效率较高
直接指针 直接指向对象 有对象指向t.class
-------------------------------------------------------------------------------------------------------------------------------------------------------

1首先一个对象被new 出来的时候尝试在栈中分配 ( 好处:一旦弹出 整个声明周期结束 不需要垃圾回收(什么对象可以在栈中new 1逃逸分析 2标量替换))
2判断对象size 大小 如果很大 那么直接仍到对内存 老年代 老年代只能通过FGC 回收
3如果对象不大 但是也不能在栈中分配 那么就分配到线程本地分配TLAB(thread local aclocation buffer)线程本地缓冲区
4如果TLAB分配不下 那么会分配到E 新生代 然后进行GC GC过程年龄到了 就到了老年代 如果没到 继续GC 知道年龄到了为止


看是否开启classpointer
是否开启oop
是否是32g内存以下
是 markwork 8 classpointer 4字节 instance padding 4 16字节
16个字节





浙公网安备 33010602011771号