深入理解计算机系统的练习题
假设我们想生成下面这个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啊?
编译器优化导致,cl是ecx的低位,在右移过程中,x >>= n,实际上相当于 x >>= (n%32);而n % 32 = n & 00011111,所以其实n的高位是什么根本不用紧,只需要最低5位,寄存器没法只拿5位,这里直接拿出低8位。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。