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,