人生第一篇博文。
《深入理解计算机系统》第二章部分习题:
2.62 int_shifts_are_arithmetic() 对int类型数使用算术右移返回1,否则返回0;
显然,只需考虑负数即可(非负数算术右移与逻辑右移相同)。这里以-1为例,-1算术右移一位,所产生的二进制码代表的数值不变;而逻辑右移则会使最高位为0,变成(1<<31)-1,最大值。
int int_shifts_are_arithmetic()
{
//printf("%x %x\n",((-1)>>1),-1);
return ((-1)>>1)==-1;
}
2.63 函数srl用算术右移实现逻辑右移,后面的代码不允许使用右移或者除法。
算术右移,若x为正数,则算术右移的结果等于逻辑右移的结果&#