在C#中对于数值想要取绝对值的时候一般大家都会用using System;中带的Math.Abs()方法,这种方法非常便捷。
但在一种情况下,取绝对值方法返回的值并不精准,我用下面的例子来展示:
假设有一个double变量 a=2.5,一个double变量b=2.6,此时用变量a减去变量b然后再用Math.Abs(a-b);方法取绝对值。
你就会发现这个方法的返回值不是0.1,而是一个无线趋近于0.1的数,值为0.10000000000000009。
所以大家在使用这个方法的时候需要注意这点。
例子运行的代码如下:
double a = 2.5;
double b = 2.6;
double c = Math.Abs(a - b);
有兴趣的朋友们可以调试程序看一看结果,我个人觉得还是挺有意思的。
本文探讨了在C#中使用Math.Abs()方法取绝对值时可能出现的精度误差问题。通过示例代码展示了当用double类型的变量进行计算时,Math.Abs(a-b)的结果并非预期的0.1,而是接近但不完全等于0.1的一个数值。作者提醒开发者在处理高精度浮点数运算时需要注意此类精度损失现象。
2742

被折叠的 条评论
为什么被折叠?



