基础集合
1多线程
-
volatile不能保证原子性
abc同时读取到0,a线程修改主内存时b操作先到达,所以a挂起线程b进行刷主操作,同时通知其他线程。此时a挂起操作导致a,b修改完成后值为1
-
cas compare and swap
atomicadd > unsafe(native方法 记录volatile对象内存地址偏移量,操作时获取偏移量拷贝到线程和主内存原始偏移量作对比,偏移量不同证明其他线程做过修改,再次获取偏移量做计算,相同后再执行计算操作) >aba(数据修改过后再修改回来,对比offset相同导致丢失中间状态)>乐观锁版本号
2 spring基础
- 循环依赖
一级缓存singtelonobject currenthashmap 单例池,经历完整的生命周期,
二级缓存 earlsingletionObject bean只经历的实例化,没有完成初始化赋值
三级缓存 singtelonFactory 未做实例化,由工厂生产
spring初始化过程
3 运维问题处理
- 快速定位top执行慢程序
一、top 查找cpu最高的进程id
二、ps -ef 或者 jps 找程序 jsp -l,
三、找到具体的线
下图含义线程2929占用cpu40分钟
四、线程id转换16进制
五、jstack 11298 |grep 2C38 -A60