代码改变世界

内存可见性、重排序、顺序一致性

2018-08-14 16:56  摘花  阅读(353)  评论(0编辑  收藏  举报

重排序:CPU可能为了提高程序执行的效率和更充分的运用计算单元,会将代码的执行顺序打乱,重新排序,而volatile会禁止指令重排序。

可见性:当某一线程修改了某个变量的值,其他线程应该立即得知这次修改(将工作内存的值同步回主存),可以通过volatile关键字实现。

原子性:指的是代码要嘛全部都run完,要么全部都down掉(要死一起死,例如Java内存模型的8种原子操作:lock、unlock、read、load、user、assign、store、write)。

有序性:对于线程本身来说,线程中的代码执行顺序是有序的。