C++Primer 2.1节难点——把-1赋给8比特大小的unsigned char所得得结果是255

把-1赋给8比特大小的unsigned char所得得结果是255

1、当我们赋给无符号类型一个超出它表示范围的值时,结果是初始值对无符号类型表示数值总数取模后的余数。

2、unsigned char的表示范围是0~255,模就是256。

3、把-1赋给8比特大小的unsigned char所得的结果是255,即-1%255=256。
有两种方法可以解释
(1)将-1加上模(256)的整数倍,使其相加后的值在0~255的区间内即可。

(2)使用取模运算的方法,首先求整数商: c = a/b,然后计算取模后的值:r = a - cb。
如c=-1/256=-1(因为是取模运算,商向负无穷取整),r=-1-(-1
256)=255。

猜你喜欢

转载自blog.csdn.net/qq_47466050/article/details/106818591
今日推荐