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


    本文由作者原创

    目录:

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

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

  • 相关阅读:
    cegui 编译过程详解(cegui-0.8.2)
    ogre3D学习基础17 --- 如何手动创建ogre程序
    ogre3D学习基础16 -- 手动创建实体(ManualObject)
    ogre3D学习基础15 -- 创建BSP Scene Manager
    ogre3D,cegui配置问题
    ogre3D学习基础14 -- 雾化效果与天空面,天空盒,天空穹
    ogre3D学习基础13 -- 键盘控制网格动画mesh
    ogre3D学习基础12 --- 让机器人动起来(移动模型动画)
    引用其他头文件时出现这种错误,莫名其妙,error C2065: “ColorMatrix”: 未声明的标识符
    STL学习笔记3--deque
  • 原文地址:https://www.cnblogs.com/spring-hailong/p/6071245.html
Copyright © 2020-2023  润新知