作者简介:大家好,我是码炫码哥,前中兴通讯、美团架构师,现任某互联网公司CTO,兼职码炫课堂主讲源码系列专题
代表作:《jdk源码&多线程&高并发》,《深入tomcat源码解析》,《深入netty源码解析》,《深入dubbo源码解析》,《深入springboot源码解析》,《深入spring源码解析》,《深入redis源码解析》等
联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬。码炫课堂的个人空间-码炫码哥个人主页-面试,源码等
回答
指令重排序是指在执行程序时,为了提高性能,处理器可能会改变指令的执行顺序。
volatile
通过内存屏障来防止指令重排序,保证有序性。volatile
提供了两种内存屏障:
- 写内存屏障:写内存屏障设置在写
volatile
变量之后。它确保对该volatile
变量的所有写操作在任何后续对同一变量的读操作之前完成。这就意味着,在写内存屏障之前的所有普通写操作(不仅仅是对volatile
变量的写操作)都将在写入volatile
变量之前完成。 - 读内存屏障:读内存屏障设置在读
volatile
变量之前。它确保对该volatile
变量的所有读操作在任何先前的写操作之后完成。这就意味着,所有在读内存屏障之后的普通读操作(不仅仅是对volatile
变量的读操作)都将在读取volatile
变量之后进行。
这种内存屏障阻止了指令重排序,确保在 volatile
变量之前的操作不会被重排序到其之后,同时也确保在 volatile
变量之后的操作不会被重排序到其之前。
详细分析
指令重排序
为了提高应用程序的性能,编译器和处理器都会我们的指令按照某种规则重新排序。简单来说就是指我们在程序中写的代码,在执行时并不一定按照写的顺序执行**。**比如下面这段代码:
int i = 0;