文章目录
一、内存屏障
二、编译器屏障
三、处理器内存屏障
一、内存屏障
----
内存屏障 , 又称为 " 屏障指令 " , 用于保证 " 编译器 “ 或 ” CPU “ 访问内存时 , 保证 按照顺序执行..., 即 ” 内存屏障 之前 “ 的指令 与 ” 内存屏障 之后 " 的指令 不会犹豫 编译器 和 CPU 优化导致 顺序混乱 ;
" 指令 " 优化主要分
2
种 :
① 编译器优化 : 为了 提高程序执行性能...指令乱序执行 , 后面的指令先于前面的指令执行 , 导致 寄存器中的值冲突 ;
Linux 内核支持的
3
种内核屏障 :
① 编译器屏障
② 处理器内存屏障
③ 内存映射 I/O 写屏障 , 全称...编译器会在编译代码时 ,
在 不影响 程序逻辑的前提下 , 对程序指令进行重排 , 主要操作是 调整程序指令的执行顺序 ;
优化后的结果 , 可能 不符合软件开发想要开发的需求 ;
三、处理器内存屏障...” 乱序执行 " 技术 , 可以在 一个时钟周期 中 并行执行多条指令 ;
但是 CPU 执行优化会导致 指令乱序执行 , 后面的指令先于前面的指令执行 , 导致 寄存器中的值冲突 ;
CPU 执行优化总结