java并发编程的三大问题

版权声明:转载请注名出处 https://blog.csdn.net/meism5/article/details/88532694

背景:
计算机处理速度:CPU > 内存 > IO
为了平衡三者的速度差异:CPU 增加了缓存;操作系统增加了进程、线程,以分时复用 CPU;编译程序优化指令执行次序
可见性:一个线程对共享变量的修改,另外一个线程能够立刻看到
原子性:一个或者多个操作在 CPU 执行的过程中不被中断的特性

1、缓存导致的可见性问题,如cpu缓存,缓存的时差性导致数据对其他线程不可见
2、线程切换带来的原子性问题,如count += 1是由三个原子指令组成
3、编译优化带来的有序性问题,如双重检查创建单例,可能取到已分配内存地址、未初始化的单例(new指令3步操作,①分内存②初始化③赋值给引用变量,可能会发生①③②的重排序)

猜你喜欢

转载自blog.csdn.net/meism5/article/details/88532694