D:指令调度。表示 CPU 已经从指令队列中取出指令,并将指令放入指令缓存区等待执行。
e:指令执行。表示指令正在被 CPU 执行。
E:指令执行完成。指令已经完成执行,并产生了相应的结果。
R:指令退役。指令已经完成执行,并已经从指令缓存区中移除。
=:指令已经调度,等待执行。指令已经被调度到指令缓存区等待执行,但是还没有开始执行。
-:指令已经执行,等待退役。指令已经在 CPU 中执行过,并且产生了结果,但是还没有从指令缓存区移除,需要等待退役。
CPU执行代码的顺序实际上与指令写入的顺序并不相同。这称为乱序执行,它对多线程程序有重大影响。
流水线和分支
clang++-11 day2.cpp -g -O3 --std=c++17 -mllvm -x86-asm-syntax=intel -S -o - | llvm-mca-11 -mcpu=btver2 -timeline
a1 += p1[i] + p2[i];
改为
a1 += (p1[i]>p2[i]) ? p1[i] : p2[i];