我可以说出使用double(或float)而不是decimal的三个优点:

使用较少的内存。 更快是因为浮点数学运算是由处理器原生支持的。 可以表示更大范围的数字。

但这些优势似乎只适用于计算密集型操作,比如在建模软件中发现的那些操作。当然,当需要精度时,不应该使用双精度,例如财务计算。那么,在“正常”应用程序中选择双位数(或浮点数)而不是十进制有什么实际的原因吗?

编辑补充: 谢谢你们的回复,我从他们身上学到了很多。

还有一个问题:一些人认为双数可以更精确地表示实数。当我宣布时,我认为他们通常更准确地代表他们。但是,当执行浮点运算时,精度可能会降低(有时会显著降低),这是真的吗?


当前回答

这取决于你要它做什么。

因为浮点数和双精度数都是二进制数据类型,所以在整数四舍五入的方法上存在一些困难和错误,例如双精度数会四舍五入0.1到0.100000001490116,双精度数也会四舍五入1 / 3到0.33333334326441。简单地说,不是所有的实数在双类型中都有准确的表示

幸运的是,c#还支持所谓的十进制浮点算术,其中数字通过十进制数字系统而不是二进制系统表示。因此,十进制浮点算术在存储和处理浮点数时不会丢失精度。这使得它非常适合需要高精度的计算。

其他回答

这取决于你要它做什么。

因为浮点数和双精度数都是二进制数据类型,所以在整数四舍五入的方法上存在一些困难和错误,例如双精度数会四舍五入0.1到0.100000001490116,双精度数也会四舍五入1 / 3到0.33333334326441。简单地说,不是所有的实数在双类型中都有准确的表示

幸运的是,c#还支持所谓的十进制浮点算术,其中数字通过十进制数字系统而不是二进制系统表示。因此,十进制浮点算术在存储和处理浮点数时不会丢失精度。这使得它非常适合需要高精度的计算。

像其他人建议的那样,以10为基数的值使用十进制,例如财务计算。

但是对于任意的计算值,double通常更准确。

例如,如果你想计算投资组合中每一行的权重,使用double,因为结果加起来更接近100%。

在下面的例子中,doubleResult比decimalResult更接近1:

// Add one third + one third + one third with decimal
decimal decimalValue = 1M / 3M;
decimal decimalResult = decimalValue + decimalValue + decimalValue;
// Add one third + one third + one third with double
double doubleValue = 1D / 3D;
double doubleResult = doubleValue + doubleValue + doubleValue;

还是以投资组合为例:

投资组合中每一行的市场价值都是一种货币价值,可能最好用十进制表示。 投资组合中每一行的权重(=市场价值/ SUM(市场价值))通常用双数表示更好。

注意:这篇文章是基于来自http://csharpindepth.com/Articles/General/Decimal.aspx的十进制类型的功能信息和我自己的解释。我假设Double是标准的IEEE双精度。

注2:本文中的最小和最大是指数字的大小。

“decimal”的优点。

“decimal”可以精确地表示可以写成(足够短的)十进制分数的数字,而double则不能。这在财务账本中很重要,在类似的地方,重要的是计算结果与人类进行计算的结果完全匹配。 “decimal”的尾数比“double”大得多。这意味着在它的标准化范围内的值,“十进制”将具有比双精度更高的精度。

十进制的缺点

It will be Much slower (I don't have benchmarks but I would guess at least an order of magnitude maybe more), decimal will not benefit from any hardware acceleration and arithmetic on it will require relatively expensive multiplication/division by powers of 10 (which is far more expensive than multiplication and dividion by powers of 2) to match the exponent before addition/subtraction and to bring the exponent back into range after multiplication/division. decimal will overflow earlier tha double will. decimal can only represent numbers up to ±296-1 . By comparision double can represent numbers up to nearly ±21024 decimal will underflow earlier. The smallest numbers representable in decimal are ±10-28 . By comparision double can represent values down to 2-149 (approx 10-45) if subnromal numbers are supported and 2-126 (approx 10-38) if they are not. decimal takes up twice as much memory as double.

我的观点是,对于金钱工作和其他与人工计算完全匹配很重要的情况,您应该默认使用“decimal”,并且在其他情况下,您应该使用use double作为默认选择。

选择应用程序的功能类型。如果你需要像财务分析那样的精确性,那么你已经回答了你的问题。但如果你的申请可以解决一个估计,你可以接受双倍。

你的申请需要快速计算还是他有足够的时间给你答案?这取决于应用程序的类型。

图形饿了吗?Float或double就足够了。金融数据分析,流星撞击行星的精准度如何?这些都需要一点精确度:)

如果你更看重性能而不是正确性,请使用浮点数。