关于机器数,真值,原码,反码,补码的认识
1.机器数
通过了解机器数后发现:机器数包含了“源码”,“反码”,“补码”的表示形式;
因为机器数指的是一个数在计算机里以二进制表示的形式,机器数的首位是符号位,正数的符号位为“0”,负数的符号位为“1”。
例如:5 的机器数是:00000101
-5的机器数是:10000101 (以8位二进制为例)
2.真值
真值指的是带符号位的机器数对应的真实数值。
对于真值而言,一般用十进制表示,也可以用二进制表示,很少用其他进制表示真值。
例如:10000101 的真值= -0000101 = -5
00000101 的真值= +0000101 =+5
3.使用原码, 反码和补码的用途
对于一个数, 计算机要使用一定的编码方式进行存储;原码, 反码, 补码是机器存储一个具体数字的编码方式。
4.原码
原码的表示形式就是第一位是符号位加上真值的绝对值。
例如:-000101(真值)= 10000101(原码)
00000101(真值)= 00000101(原码)
因为第一位是符号位,所以原码在8位二进制的范围为:
11111111~01111111 即 -127~127
原码是最容易被大脑理解,计算的表示形式。
5.反码
反码就是在原码的基础上,如果是正数,就和原码一样,如果是负数,首位符号不变,其余数值取反。
例如:00000101(原码)= 00000101(反码)
10000101(原码)= 11111010 (反码)
反码不容易被大脑理解,通常被转换成原码后计算。
6.补码
补码是在原码的基础上,如果是正数,就和原码一样,如果是负数,除首位符号外,其余数值取反(反码),在它的基础上 +1。
例如:00000101(原码)= 00000101(反码)= 00000101(补码)
10000101(原码)= 11111010 (反码)= 10000011(补码)
对于负数, 补码表示方式也是人脑无法直观看出其数值的,通常也需要转换成原码再计算其数值。
7.使用原码, 反码和补码的历程
只使用原码容易被理解,但是对于计算机而言要辨别首位正负,要消耗大量资源,于是人们寻找到了利用符号位参与运算的方法。
我们知道, 根据运算法则减去一个正数等于加上一个负数, 即: 1-1 = 1 + (-1) = 0 , 所以机器可以只有加法而没有减法, 这样计算机运算的设计就更简单了。
探索计划1.0(原码):
1+ (-1) = 0
00000001(原码)+10000001(原码)=10000010(原码)= -2
探索原码计算首位计划失败
追加投资!
探索计划2.0版本出世(反码):
00000001(原码)+10000001(原码)= 00000001(反码)+11111110(反码)= 11111111(反码)=10000000(原码)= -0
更新说明:解决了首位符号参与运算的问题,很大程度上减少计算机对二进制运算所消耗的资源,但是出现“0”和“-0”重复的情况,还可以改进!
探索计划3.0版本出世(补码):
00000001(原码)+10000001(原码)= 00000001(反码)+11111110(反码)= 00000001(补码)+11111111(补码)=00000000(补码)=00000000(原码)= 0
追加:(-1)+(-127)= (-128)
10000001(原码)+11111111(原码)= 11111110(反码)+10000000(反码)= 11111111(补码)+10000001(补码)=10000000(补码)=-128
更新说明:解决了2.0版本存在的一个无意义的二进制“-0”,对二进制范围进一步扩大由1.0版本的(-127~127)升级为(-128~127)同理也可以用于其他位的二进制
例如:int有4个字节32位,表示的范围为(-2^31~2^31-1)
由于3.0版本更符合环保理念,所以作为计算机储存二进制的不二之选。