原码:

最高位为符号位。。0代表正数 1 代表负数

+1:0000 0001

-1:1000 0001

+0:0000 0000

-0: 1000 0000

问题:

1.0这个数值在存储的时候,有2种存储方式

2.正数和负数相加的时候,结果不是我们所算出的结果(在计算机里面,只能做加法运算)

1-1 = 1 + -1

1: 0000 0001

-1:1000 0001

加法:10000010 = -2

反码:符号位不变,其他位进行0和1的对换(为补码做铺垫)

结论:正数的反码和原码、补码是一样的

+1 :0000 0001

-1 : 1000 0001

+0:0000 0000

-0: 1000 0000

-0的反码:1111 1111

反码

+1 : 0000 0001

-1 :1111 1110

加法运算 :1111 1111 = -0

解决:加法运算的结果问题

0的存储没有解决

补码:

1.补码就是在反码的基础上加1;

2.正数的反码和原码、补码是一样的

+1 :0000 0001

-1 :1000 0001

1111 1110

1111 1111

-0: 1000 0000

1111 1111

10000 0000

做加法:+1 + -1(补码)

0000 0001

1111 1111

10000 0000 -0

+0 : 0000 0000

-0 : 0000 0000

结论:解决了0的存储问题

最终:计算机的数据存储时以补码的方式进行存储。

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐