计算机为什么用补码存储数据?

本文由作者原创

目录:

  1、无符号数和有符号数的区别

  2、原码,反码,补码

  3、计算机为什么使用补码存储数据

 


 

1、无符号数和有符号数的区别

  数据在计算机中都是以二进制串的形式存储!字节是内存的基本单位,计算机存储和管理数据以字节为最小单位(还有  字、双字)。

  首先要分清无符号数和有符号数:

    无符号数:无符号数就是没有正负号之分,表示的是自然数(自我理解)

    有符号数:有符号数有正负号之分,在计算机中0表示正数,1表示负数

    例:对于一个字节来讲

    无符号数能表示的范围是:0~255

    有符号数能表示的范围是:-127~128

  注:其实对于相同字节数的无符号数和有符号数,它们能表示的的个数是相同的,只是我们人为的赋予了不同给的含  义,使它能表示的范围有了改变。

 

 


 

2、原码,反码,补码

  对于无符号数来讲它是没有原码,反码,补码之分的。(原码,反码,补码相同)

  有符号数才有原码,反码,补码编码方式

  数分为正数和负数两大类(计算机外部,也就是人为的区分)

  正数的原码,反码,补码相同

  负数的原码,反码,补码的相互转换规则是:负数的补码是原码取反加1(转换过程不设计符号位)

    例1:负数-12(当然我以字节为单位存储)

    原码:10001100

    反码:11110011

    补码:11110100(计算机存储的是补码,操作时都以补码操作)

    例2:正数 12

    原码:00001100

    反码:00001100

    补码:00001100

  补充:不管是二进制,十进制,还是十六进制相加的规则是一样的“满则进1”。

 

 


 

 

3、计算机为什么使用补码存储数据

  在计算机数据都是以补码的方式存储的,我认为原因主要以下两个(自我理解)

    优点:

    1.避免了0的编码有两个

    2.符号位和有效值位可以一起处理,减法通过加法就可以实现,即简化了计算机的结构设计也提高了运算速度。

    补:计算机的加减运算都是通过加法实现的,乘除运算都是通过乘法实现的(当然有的计算机有乘法器,有的计算      机无乘法器,乘法也是由加法器实现的)

转载于:https://www.cnblogs.com/spring-hailong/p/6071245.html

你可能感兴趣的:(计算机为什么用补码存储数据?)