CPU多级缓存结构
java 线程依赖内核线程
mesi 缓存一直性原理(修改、独占、共享、无效)-- 解决可见性,状态变更发送消息(总线嗅探机制)
总线锁 锁总线(效率较低)
多线程
线程上下文切换 ,任务执行数据(寄存器数据,指令指针等) 存放在TSS(任务状态断)
死锁
jps 查看java 线程
jstack 线程id 查看详情
JMM (工作内存、主内存)
规则 原子性、有序性、可见性
jvm 内存区域
方法区、程序计数器、Java虚拟机栈、本地方法栈、堆内存(元空间)
volatile 修饰的变量汇编指令会增加#lockl前缀
lock前缀指令实际上相当于一个内存屏障(也成内存栅栏),内存屏障会提供3个功能:
1)它确保指令重排序时不会把其后面的指令排到内存屏障之前的位置,也不会把前面的指令排到内存屏障的后面;即在执行到内存屏障这句指令时,在它前面的操作已经全部完成;
2)它会强制将对缓存的修改操作立即写入主存;
3)如果是写操作,它会导致其他CPU中对应的缓存行无效。
synchronised
每个对象对应一个监视器(moniter)对象
moniterenter、moniterexit 进入退出监视器对象实现
线程获取锁失败会放入waitset 集合中