开发者社区> 问答> 正文

关于C代码转为汇编的疑问

深入理解计算机系统的练习题
假设我们想生成下面这个C函数的汇编代码:
int shift_left2_rightn(int x,int n){
x <<=2;
x >>= n;
return ;
}
下面这段代码执行实际的移位,并将最后的结果放在寄存器%eax中。此处省略了两条重要
的指令。参数x和n分别存放在存储器中相对寄存器%ebp中地址偏移8和12的地方。
1 movl 12(%ebp),%ecx Get n
2 movl 8(%ebp),%eax Get x
3 sall $2,%eax x <<=2
4 sarl %cl,%eax x>>=2
根据右边的注释,填出缺失的指令。请用算术右移指令。
gcc编译的。
3和4行是要填的。我把答案直接写出来了。
我的疑问是:4填的为什么不是 sarl %ecx,%eax。
因为%ecx保存的才是n啊?

展开
收起
a123456678 2016-03-19 17:46:23 2700 0
1 条回答
写回答
取消 提交回答
  • 编译器优化导致,cl是ecx的低位,在右移过程中,x >>= n,实际上相当于 x >>= (n%32);而n % 32 = n & 00011111,所以其实n的高位是什么根本不用紧,只需要最低5位,寄存器没法只拿5位,这里直接拿出低8位。

    2019-07-17 19:08:24
    赞同 展开评论 打赏
问答分类:
问答标签:
问答地址:
问答排行榜
最热
最新

相关课程

更多

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载