c/c++语言开发共享浮点乘以零是否保证产生零?

我知道浮点数有舍入错误,但我想知道是否存在错误不适用的某些情况,例如乘以零。

对于所有浮点,任何数字的零次是否为零?

    假:

    0f * NAN == NAN 0f * INFINITY == NAN 

    和……

     0f * -1f == -0f (negative 0f), with 0f == -0f :-) 

    (在Intel,VC ++上,可能在任何使用IEEE 754-1985浮点的平台上)

    关于ideone的示例(可能在某些Intel兼容平台上使用GCC)

    除了@xanatos的好答案之外, 还要考虑OP的一些中间问题:

    我想知道是否存在(舍入)错误不适用的某些情况

    候选人包括some_double_y = some_double_x * 1.0some_double_y = some_double_x + 0.0可能永远不会产生舍入错误。

    然而,即使那些也是可疑的,因为编译器可能会以更高的精度评估double ,考虑到FLT_EVAL_METHOD == 2 ,其中“评估所有操作和常量到long double类型的范围和精度”。 在这种情况下,中间some_double_x可以作为与表观double some_double_x0.01.0不同的long double some_double_x存在。

    需要了解更多c/c++开发分享浮点乘以零是否保证产生零?,也可以关注C/ C++技术分享栏目—计算机技术网(www.ctvol.com)!

      以上就是c/c++开发分享浮点乘以零是否保证产生零?相关内容,想了解更多C/C++开发(异常处理)及C/C++游戏开发关注计算机技术网(www.ctvol.com)!)。

      本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

      ctvol管理联系方式QQ:251552304

      本文章地址:https://www.ctvol.com/c-cdevelopment/980091.html

      (0)
      上一篇 2021年12月13日
      下一篇 2021年12月13日

      精彩推荐