• 计算机中如何表示数字-07IEEE754浮点数标准


    由于不同机器所选用的基数、尾数位长度和阶码位长度不同,因此对浮点数的表示有较大差别,这不利于软件在不同计算机之间的移植。为此,美国IEEE(电器及电子工程师协会)提出了一个从系统角度支持浮点数的表示方法,称为IEEE754标准(IEEE,1985),当今流行的计算机几乎都采用了这一标准。
    IEEE754标准在表示浮点数时,每个浮点数均由三部分组成:符号位S、指数部分E和尾数部分M,如下:
    符号位S 指数E 尾数M
     IEEE754标准的浮点数采用以下四种基本形式:
    1.单精度(32位):E=8位,M=23位;
    2.拓展单精度:E>=11位,M=31位;
    3.双精度(64位):E=11位,M=52位; 
    4.拓展双精度:E>=15位,M>=63位。
    例:标准32位单精度浮点数各部分规定
    S:数符,0表示‘+’,1表示‘-’;E:指数,既阶码部分,其中包括1位阶符和7位数值,采用移127码,既移码值位127。所谓‘移127’码是一种特殊的移码,指阶码部分采用的移码的值与实际数据的指数的值满足关系:阶码=127+实际指数值。规定阶码的取值范围为1~254,阶码值255和0用于表示特殊值。M:尾数共23位,用源码的规格化表示。由于采用规格化表示,所以IEEE754标准约定在小数点左边有一位隐含位为1,从而使尾数的实际有效位为24位,既尾数的有效值为1.M。综上,32位单精度浮点数所表示的数值N为:
    N=(-1)S * 1.M * 2^(E-127)
    IEEE754标准32位单精度浮点数的解释如下:
    若E=0,且M=0,则N为0。
    若E=0,且M<>0,则N=(-1)^s*2^(-126)*(0.M),为非规格化数。
    若1<=E<=254,则N=(-1)^s*2^(E-127)*(1.M),为规格化数。
    若E=255,且M<>0,则N=NaN(非数值)。
    若E=255,且M=0,则N=(-1)^s*(无穷大)。在java当中有被更加详细的划分为正无穷大和副无穷大。 
    标准64位双精度浮点数也可以同理的得到。
    Java中浮点数,既float和double,都是采用的IEEE754标准。
  • 相关阅读:
    170322操作系统定义、功能、位置与历史
    java 多线程
    java 网络编程TCP程序设计
    java 事件处理机制
    java GUI编程
    170321php3第4章 PHP5的基本语法+作业九九乘法表
    170320网络编程 udpclient udpGroupClient
    二叉树线索化
    哈希表
    二叉搜索树
  • 原文地址:https://www.cnblogs.com/xieji233/p/6155647.html
Copyright © 2020-2023  润新知