java并发编程的三大问题
背景:
计算机处理速度:CPU > 内存 > IO
为了平衡三者的速度差异:CPU 增加了缓存;操作系统增加了进程、线程,以分时复用 CPU;编译程序优化指令执行次序
可见性:一个线程对共享变量的修改,另外一个线程能够立刻看到
原子性:一个或者多个操作在 CPU 执行的过程中不被中断的特性
1、缓存导致的可见性问题,如cpu缓存,缓存的时差性导致数据对其他线程不可见
2、线程切换带来的原子性问题,如count += 1是由三个原子指令组成
3、编译优化带来的有序性问题,如双重检查创建单例,可能取到已分配内存地址、未初始化的单例(new指令3步操作,①分内存②初始化③赋值给引用变量,可能会发生①③②的重排序)
【Java面试题与答案】整理推荐