深入理解计算机系统3

一、加载有效地址leaq

有效地址:

Imm(rb, ri, s) → Imm + R[rb] + R[ri] · s

写入到目的寄存器 

可以用来表示加法和有限的乘法运算

比例因子取值只能是 1,2,4,8 这四个数中的一个,所以乘法运算需要多步完成

二、移位操作SAL  SHL…………

算术右移=C右移

逻辑右移需要填零

可以用来计算2的许多次方

乘法指令的执行需要更长的时间,故不宜

三、条件码

 (主要用于逻辑判断)

根据标志的值和它们的位运算对寄存器进行赋值,这样我们常见的逻辑表达式的值都能算出来。

如:

根据符号标志 (SF) 和溢出标志 (OF) 的异或结果,可以对 a小于 b 是否为真做出判断

根据零标志 (ZF) 的值对寄存器al 进行赋值,判断两数相等

四、跳转指令

判断究竟是顺序执行,还是跳转到 L4 处执行

if-else 语句执行效率可能会比较低

解决方案:分别用两个变量来记录结果,根据测试情况来判断是否更新返回值

原因:

当遇到条件跳转时,处理器会根据分支预测器来猜测每条跳转指令是否执行,当发生错误预测时,会浪费大量的时间,导致程序性能严重下降。

五、循环

条件测试导跳转的结合

for while代码:这两个汇编代码是采用-Og 选项产生的

[ -Og ]是一个比-O0更好的选择来生成可调试代码,因为在-O0处禁用了一些收集调试信息的编译器通道。

六、switch 语句

跳转表

与使用一组很长的 if-else 相比,使用跳转表的优点是执行 switch 语句的时间与

case 的数量是无关的。因此在处理多重分支的时,与一组很长的 if-else 相比,

switch 的执行效率要高

只用跳一次,不用跳来跳去

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值