volatile保证了有序性。这里的有序性,不是前面所说的指令交错的问题,而是指令中更底层的东西。
指令重排
JVM在不影响正确性的情况下,会对语句的执行顺序来进行重排。为了提高指令执行的效率。
名词
Clock Cycle Time
主频的概念大家接触的比较多,而 CPU 的 Clock Cycle Time(时钟周期时间),等于主频的倒数,意思是 CPU 能够识别的最小时间单位,比如说 4G 主频的 CPU 的 Clock Cycle Time 就是 0.25 ns,作为对比,我们墙上挂钟的Cycle Time 是 1s
例如,运行一条加法指令一般需要一个时钟周期时间
CPI
有的指令需要更多的时钟周期时间,所以引出了 CPI (Cycles Per Instruction)指令平均时钟周期数,即平均一个指令需要执行的时间周期是多少。
IPC
IPC(Instruction Per Clock Cycle) 即 CPI 的倒数,表示每个时钟周期能够运行的指令数
CPU 执行时间
程序的 CPU 执行时间,即我们前面提到的 user + system 时间,可以用下面的公式来表示
程序 CPU 执行时间 = 指令数 * CPI * Clock Cycle Time
指令重排序优化
在java层面,我们看到的最小层级是javap锁编译出来的指令。但程序在执行过程中,更底层,一个指令可以拆分成更小的阶段,比如,划分为五个阶段:取指令,指令译码,执行指令,内存访问&#