《深入理解计算机系统》第二章部分习题

本文介绍了《深入理解计算机系统》第二章的部分习题解答,包括算术右移与逻辑右移的区别,以及无符号数乘法的高精度计算方法。涉及到的习题包括2.62、2.63、2.65、2.66和2.75,解释了如何通过算术右移实现逻辑右移,并探讨了无符号数乘法后的高精度结果处理。
摘要由CSDN通过智能技术生成

人生第一篇博文。
《深入理解计算机系统》第二章部分习题:
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为正数,则算术右移的结果等于逻辑右移的结果&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值