The-Art-of-Writing-Efficient-Programs 学习笔记2

文章探讨了CPU如何通过乱序执行优化性能,其中涉及到指令调度、执行和退役的过程。流水线和分支预测技术在处理多线程程序时起到关键作用,特别是对于代码如a1+=p1[i]+p1[i]与a1+=(p1[i]>p2[i])?p1[i]:p2[i]的不同处理方式。
摘要由CSDN通过智能技术生成

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];

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值