原码 反码 补码总结:
个人学习用,水平有限
问题的引入:
关于8位能表示的最大的数据范围(有符号整型与无符号整型)
由于计算机数据的存储是补码类型:根据一开始学习的补码是由反码+1得到的,在分析-128的补码形式上就犯了难。
因为8位数据(7位数据位与1位有效位)-127的原码为11111111,反码为10000000。
7位数据位最多能表示的数据范围就是0~127,根本没有128,所以是不是8位数据里面根本就没有-128的存在,数据类型只能是-127~127
问题的分析:
(1)模的概念:在数电中计算一个计数器电路的进制时,我们使用过“模”的概念。这个计数器能从0~11计数,到11产生进位信号,那么这个“模”就是12。那么在这里,8位数据(0-255),计数到255产生进位,模为256.
(2)补码的定义:这个是我在浏览文章中找到的,一个补码其实是定义为模减去其绝对值。这个定义个人认为可以有效的规避原码与反码自身存在的缺点。
(3)在位数相同的情况下,反码与原码都存在着0与-0的表示形式不同的问题,但我们人是认为0与-0是同一个数。补码却没有这个缺陷,这就导致补码能表示的数值范围要比原码与反码多1,多出来的这个1恰恰就是-128。它没有与其相对应的反码与原码,但却存在着自己的补码!!!
-128的补码 = 256 - |-128| = 128 = 10000000