原码,反码和补码

本文详细介绍了原码、反码和补码的概念及计算方式,特别关注于负数的处理。阐述了计算机为何使用补码,主要是为了简化运算(减法转加法)并消除两个零的表示。此外,还探讨了计算机存储数据的方式,以及类型转换可能引起的精度损失,特别是通过补码形式进行的强制类型转换示例。
摘要由CSDN通过智能技术生成

一.原码反码和补码的计算方式

1.对一个正数

二进制原码反码和补码完全相同。

例如 int i=150;
对应的二进制原码:00000000 00000000 00000000 10010110;
对应的二进制反码:00000000 00000000 00000000 10010110;
对应的二进制补码:00000000 00000000 00000000 10010110;

2.对一个负数

二进制的反码等于原码符号位不变,其它位置取反。
二进制的补码等于反码加一。

例如 int i = -150;
对应的二进制原码:10000000 00000000 00000000 10010110;
对应的二进制反码:111111111 11111111 11111111 01101001;
对应的二进制补码:111111111 11111111 11111111 01101010;

二.计算机为什么要引入补码

关于补码的作用,有如下解释:
(1)化减为加:
由于计算机CPU中只有加法器,没有减法器,所以在计算机采用原码做减法会存在一些问题:
例如1-1=0:
对计算机而言,它把这个减法看做是1+(-1)=0 。用二进制表示则为 0001+1001=1001, 这个结果为十进制的负1而不是0,很明显出现了错误。补码的出现很好的解决了这个问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值