-0

王朝百科·作者佚名  2010-02-28
窄屏简体版  字體: |||超大  

−0代表负零,一个计算机科学中存在的数字。主要用来表达浮点数和在某些对整数进行有符号数处理。在数学中,一般没有正零或负零的概念,−0在逻辑上表示0的相反数,等于0。

在普通应用中,-0有可能被用来表示一个可以四舍五入为零的负数,或者是一个从负方向上趋近于零的数。在统计力学中,特定的系统在反转分布的状态下,可以被认为拥有-0的绝对温度。

表示法在对于整数的1+7比特的符号数值表示法中,负零是用二进制代码10000000表示的。在8比特二进制反码中,负零是用二进制代码11111111表示。在IEEE 754二进制浮点数算术标准中,指数和尾数为零、符号比特为一的数就是负零。

在IBM的普通十进制算数编码规范中,运用十进制来表示浮点数。这里负零被表示为指数为编码内任意合法数值、所有系数均为零、符号比特为一的数。

性质与处理在编程语言中,例如C,C#,C++和Java,一个表达式的结果可能是负零(比如对一个负数算术下溢时的结果),此时负零和正零是等效的。因此一个简单的比较不能够确定一个数是负零。确定一个数是负零的办法包括:

使用IEEE 754中定义的copysign()函数复制零的符号到任意非零的数上。

用一个正数来除以这个零——得到的无穷能够反映出零的符号

在Java中,用Double类中的equals方法,能够分辨出正零和负零,例如:

Double negativeZero = new Double(-0.0);

negativeZero.equals(-0.0); // 结果:真

negativeZero.equals( 0.0); // 结果:假

在C语言中,使用一个依赖于本地硬件表示法的不方便的办法。例: *(int *)&var == 0x80000000 (var在IEEE 754中编码单精度)。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航