zoukankan      html  css  js  c++  java
  • 计算机为什么用补码存储数据?

    本文由作者原创

    目录:

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

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

  • 相关阅读:
    uva 10306
    系统学习Linux的11点建议
    SharePoint 2013 讨论板列表"Connect to Outlook" 不可用解决方案
    Java可视化编程,基于布局管理器的UI设计
    【JavaScript脚本编程技术详解-----(一)】
    一个百度程序员的创业故事
    HDU 4729 An Easy Problem for Elfness (主席树,树上第K大)
    Android SQLite Database Tutorial
    最优化方法在图像处理中的应用【4】
    [置顶] 编辑框Editext光标最后显示
  • 原文地址:https://www.cnblogs.com/spring-hailong/p/6071245.html
Copyright © 2011-2022 走看看