C#中Console.WriteLine(0.1f * 10 == 1.0f)的输出为什么是False
因为两个值 不相等 所以是false 要不然 是true
Console.WriteLine(0.1f);
Console.WriteLine(0.1f*10);
Console.WriteLine(1.0f);
Console.WriteLine(0.1f * 10 == 1.0f);
Console.WriteLine("{0} == {1}", 0.1f * 10, 1.0f);
Console.WriteLine(0.1f * 10);
Console.WriteLine(1.0f);
float f1 = 0.1f * 10;
float f2 = 1.0f;
Console.WriteLine(f1 == f2);
Console.WriteLine("====================");
Console.ReadKey();
你可以试试这段代码
我觉得是因为写法的问题
抱歉
具体细节我没办法弄清楚
但是这段代码可以完全证明float 的事情和double 没有关系
你细细读读他的理解
有些地方并不能说明问题
并且你可以做进一步的试验
float y = 0.1f;
float xy = x * y;
Console.WriteLine(xy==1);
这样就可以显示true了
我想问的是,我那个错在哪里?
我怀疑因为浮点数采用IEEE754的表示方法,在运算中0.1f和10都会转化为double来运算,你可以试一下Console.WriteLine("{0}", Convert.ToDouble(0.1f));结果并不是0.1而是 0.100000001490116,我上面给出的方法相当于是隐式转化0.1f * 10为float 即隐式转换double到float,所以结果是true,而Console.WriteLine(0.1f * 10 == 1.0f)是在拿一个double和一个float来比较,所以是false,你可以试试
double d = 0.1;
float f = 0.1f;
Console.WriteLine(d == f);
结果是false