【C/C++基础】02_二进制原码、反码与补码之间的关系

本文介绍了计算机中表示数值的机器数和真值概念,详细阐述了原码、反码和补码的定义及其相互关系。通过实例解析了二进制数在不同编码方式下的转换,强调了补码在解决减法运算和表示范围内的重要作用。此外,还涉及了小数的二进制与十进制转换方法。
摘要由CSDN通过智能技术生成

1 机器数和真值

1.1 机器数

一个数在计算机中的二进制表示形式, 叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1.比如,十进制中的数 +3 ,计算机字长为8位,转换成二进制就是00000011。如果是-3 ,就是 10000011 。那么,这里的 00000011 和10000011 就是机器数。计算机中的数字是以二进制补码的方式存储的。

1.2 真值

因为第一位是符号位,所以机器数的形式值就不等于真正的数值。例如上面的有符号数 10000011,其最高位1代表负,其真正数值是 -3 而不是形式值131(10000011转换成十进制等于131)。所以,为区别起见,将带符号位的机器数对应的真正数值称为机器数的真值。

例1:0000 0001的真值 = +000 0001 = +1,10000001的真值 = –000 0001 = –1

例2:在C语言中有以下程序段:

链接:https://www.nowcoder.com/questionTerminal/ef47c08580b24f8582b629459b224ea0
来源:牛客网

char ch=-1;

printf(“%02x,%02x”,ch,(unsigned char)ch);

则输出的结果是:ffffffff,ff

(1) %x表示十六进制整数输出,所以char要扩展成四字节的int。%02x表示输出 最少 2位,不足补0.

(2) 负数在计算机中是以补码形式存在的,正整数的补码是本身,负数的补码是除符号位以外各位都取反加一,也就是如果一个32位的负数原来是1(符号位)00 ... ... 01, 取反后是1(符号位)11 ... ... 10,然后再加1,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值