八位计算机数据表示范围,为什么8位有符号定点数的表示范围是-128~127?

本文写作时长3小时

计算机中,定点数的表示法有三种:原码,反码,补码。99%的计算机使用补码表示。

由于无符号定点数的原码,反码,补码都是一样的,所以也所谓什么原反补了。

原码

有符号数的原码表示

最高位为符号位,其余位数表示数值

符号位占据位7(第8位),剩余7位表示值

正数部分

最大为0111 1111,十进制为127

0000 0000到0111 1111,+0到+127,共128个数

负数部分

最小为1111 1111,十进制为-127

1111 1111到1000 0000,-127到-0,共128个数

0的表示法

1000 0000 ,十进制为-0

0000 0000,十进制为+0

0的表示法用原码有两种形式,这是不行的

关于运算

试试用原码进行1+(-1)运算

0000 0001

1000 0001

1000 0002

结果等于-2,wrong

假定+0和-0是两个数

8位有符号数的原码可以表示256个数

然而+0和-0是没有意义的,认为是一个数的话,就是255个数

无符号数的原码表示

由于没有符号位,所以8位都是数值位

最小0000 0000,十进制为0

最大1111 1111,十进制为255

范围是0~255,共256个数

反码

反码规定:正数部分的反码与原码相同,负数部分的反码除去符号位各位取反

有符号数的反码表示

负数部分

原码表示

1111 1111到1000 0000

所以反码(去除符号位,各位取反)为

1000 0000到1111 1111

正数部分

原码表示

0000 0000到0111 1111

反码(和原码相同)为

0000 0000到0111 1111

范围是1000 0000~0111 1111,-127~127

也是256个数

关于0的表示

反码的0也有两种

1111 1111 和 0000 0000

看来反码也不行啊 (○´・д・)ノ

关于运算

看看1+(-1)的问题解决了吗

0000 0001

1111 1110

1111 1111

等于0,运算问题解决了,但是0的表示法的问题依旧没有解决

无符号数的反码表示

与原码相同

补码

补码规定:正数部分的补码与原码相同,负数部分的补码为除去符号位反码+1

有符号数的补码表示

负数部分

原码

1111 1111到1000 0000

反码(去除符号位,各位取反)

1000 0000到1111 1111

补码 (反码+1)

1000 0001到1000 0000(溢出)

正数部分

原码表示

0000 0000到0111 1111

反码(和原码相同)为

0000 0000到0111 1111

补码(和原码相同)

0000 0000到0111 1111

关于0的表示

按照这个规则其实0的表示还是两种

1000 0000 和 0000 0000

只不过,1000 0000规定为-128

所以0的表示就唯一了

负数部分:1000 0000、1000 0001到1111 1111

就是 -128,-127到-1,所以就是-128到-1

正数部分:0000 0000到0111 1111

就是0到127

整体就是-128-127,嗯,可以

关于运算

1+(-1)

0000 0001

1111 1111

0000 0000(溢出)

刚好是0000 0000

至此,运算问题解决,0的表示问题解决。那就补码了。

为什么要有原码,反码,补码?

有很多原因,只单单从本文角度简单地来说

原码:解决数值的符号问题

反码:解决相同数值正负相加不等于0的问题

补码:解决0的表示不唯一的问题

4bcf48987c1f

注意:

** 补码的推导过程(本文,以及绝大多数教材)并不完全正确。如果单单从上述观点去理解补码,是理解不了补码的,上述观点只是从结果的某一方面来说,简单粗暴的进行补码推导。**

理解有限,欢迎指正!

  • 5
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值