-2
我有双重变量,它的值是:double.ToString()在C#中返回错误值
double d = 0.000000000000056843418860808015;
当我打印这个变量的打印错误。
d.ToString();
输出: “5.6843418860808E-14”
如何解决这个问题?
我有双重变量,它的值是:double.ToString()在C#中返回错误值
double d = 0.000000000000056843418860808015;
当我打印这个变量的打印错误。
d.ToString();
输出: “5.6843418860808E-14”
如何解决这个问题?
那么如果你想有一个输出,而不需要格式化您的字符串指数表示:
d.toString("F25");
这会给你与多达25位小数“正确”的数量。
0,0000000000000568434188608
编辑:格式和转换的完整列表,请here和快照对你来说是下方。
Original value: 1054.32179
F: 1054.32
F0: 1054
F1: 1054.3
F2: 1054.32
F3: 1054.322
double d = 0.000000000000056843418860808015;
var str = d.ToString("G17");
var value = str.Split('E')[0];
var zeros = Int32.Parse(str.Split('E')[1]);
var outputString = "";
zeros = Math.Abs(zeros);
var addstring = "0.";
for (var i = 0; i < zeros - 1; i++)
{
addstring += '0';
}
value = value.Remove(1, 1);
value = addstring + value;
请解释一下什么是 “错” 与格式化值? – dasblinkenlight
@dasblinkenlight对他来说这是“错误的”,因为这不是OP期望的。 OP应该了解科学记数法:https://en.wikipedia.org/wiki/Scientific_notation。 – aloisdg