public class Bar {
int a = 1;
static int b = 2;
public static void main(String[] args) {
System.out.println(b);
}
}
检查Bar堆栈->保存上一栈帧基础地址(基于在内存里都是线性编址,所以需要约定一块内存空间)
新的一帧帧分配一块空间(int宽度)->对象定义(声明+定义)->1 寄存器内部发现了有cpu时钟,this对象地址(地址码)后面贴着变量对象的内存地址,从对应下标往下索引多少位占据为int字节长度(1),其他按cpu高低位补位00,这里是在当前类堆内存。
静态和局部的修饰符都在方法区里面,但经过编译器到了汇编层面,内存里是没有按这些功能的抽屉去划分的。
新定义对象的内存偏移到方法区(因为是静态的)内,采取先去定义在偏移。