对于数值存储有补码、原码、反码三种方式:
补码:解决负数加法运算正负零问题,弥补了反码的不足。
原码:可直观反映出数据的大小。
反码:解决负数加法运算问题,将减法运算转换为加法运算,从而简化运算规则
负值采用反码的形式进行存储,计算机通过第一位来判断一个数值是否为负数,当第一位为1时,则为负数,否之则为正数,而对于负数想要得到为十进制的负数则需要对其取补码的补码,接下来以实例解析:
对于数值-5而言,5的二进制为0000 0101,取反码为1111 1010,补码则为1111 1011,将其存储至计算机中。
对于数值6而言,其二进制为0000 0110,将其存储至计算机中。
对于数值3而言,其二进制为0000 0011,将其存储至计算机中。
当我们对-5+6进行运算时,计算机直接将两个二进制相加,得到0000 0001,此时其第一位为0,则判断为正数1。
当我们对-5+3进行计算,得到1111 1110,判断得到第一位为1,则为负数,对其取的补码为0000 0010,则其为-2。
在计算机中,采用负数存储为补码的形式,可以在计算时不管其是否为正负数,直接对二进制值相加即可得出结果,至于对最终结果想解释为无符号还是有符号,完全取决于编译器的解释,如下一段C语言程序:
int c = -5;
printf("%d,%u\r\n",c);//%d表示有符号打印,而%u表示无符号打印
其输出结果如下图:
总结:
对于有符号和无符号而言,取决于编译器对其的解释,而对于负数以补码形式存储,则是为了方便计算。