=======================================================================
之所以为写这篇文章,是为了帮助自己区分一下 计算机内反码,和其它应用环境中的反码的差别,以前一直 认为反码就是 计算机内反码,其实还存在着其它方面。
前几日研究TCP、UDP、链路层 的 检验和 时有了 这个疑问。慢慢一想,原来是把定义搞混了。
这里对原码、反码、补码的介绍很简单,
另外附上一篇详细介绍原码、反码、补码的博客:https://www.cnblogs.com/zhangziqiu/archive/2011/03/30/ComputerCode.html
=======================================================================
先来谈一谈计算机内的反码:
原码、反码、补码是计算机内数值存储的3中方式。
计算机内为什么要引入反码的概念?其实应该问为什么要引入补码的概念,反码只是原码向补码过度过程中的一个中间产物。
我们都知道,计算机在计算加法时效率是最高的(同时计算机硬件的设计也会最大程度上被简化)。因此为了将减法计算转换为加法计算,引入了补码的概念。
正数的原码、反码、补码均是其本身
负数的反码是,符号位不变,其余各位按位取反;负数的补码,是在负数反码的基础上+1。
下面我们看一个公式:
依据定义有X - Y =X +(-Y)= X + [-Y]补,这样一个减法就顺利的转换为了加法。
接下来谈一谈计算机外的反码:
首先,要放下计算机内反码的定义,因为那是在计算机内这个范围内为了达到一定目的而专门定义的。
而在计算机外部,反码就是最耳熟能详的说法,所有位 ,按位取反,就得到了反码。(模2)拿一个8位二进制数 1010 1111举例,它的反码就是0101 0000。