C# --- 浮點數類型 float, double, decimal
- float, double, decimal
- decimal
float, double, decimal
decimal
- double 和 float 的采用base 2, 不能精確的表示浮點數, 進行加減乘除的操作的時候會出現精度丟失的問題
- decimal 采用base 10,可以精確的表示浮點數,加減乘除的時候不會出現精度丟失的問題
double x = 0.1;
double value = 0.0;
for (int i = 0; i < 1000; i++)
{value += x;
}
Console.WriteLine(value);
//output: 99.9999999999986
decimal x = 0.1M;
decimal value = 0.0M;
for (int i = 0; i < 1000; i++)
{value += x;
}
Console.WriteLine(value);
//output: 100.00
- decimal的缺點是內存占用大,處理速度慢(大概比double慢10倍)