2

可能重复:
C# 中的 Decimal、Float 和 Double 有什么区别?

帮我。

我正在用 C# 开发一个应用程序。我在尝试:

DateTime dtm1 = new DateTime(2012, 11, 15, 11, 3, 0);
DateTime dtm2 = new DateTime(2012, 11, 15, 11, 3, 20);
TimeSpan timespan3 = dtm2 - dtm1;
decimal _Hour = Convert.ToDecimal(timespan3.TotalHours);

什么时候做这样的输出如下:

 _Hour = 0.00555555555555556M

而这不完全是,当使用是一种双倍输出时:

 double _Hour = timespan3.TotalHours;

 output: 0.0055555555555555549

一个例子:

public decimal tinhDienTichHinhThang(decimal D1, decimal D2, decimal H)
        {
            //tính tổng 2 đáy
            decimal tong2Day = D1 + D2;
            //cộng vào nhân chiều cao :))
            tong2Day = tong2Day * H;

            //return diện tích
            return tong2Day / 2;
        }


DateTime dtm1 = new DateTime(2012, 11, 15, 11, 3, 0);
DateTime dtm2 = new DateTime(2012, 11, 15, 11, 3, 20);
TimeSpan timespan3 = dtm2 - dtm1;

///progress
///cal1: _Hour
///cal2: decimal D1 = 0.25
///cal3: decimal D2 = 5
///cal4: decimal D3 = 0.9

decimal test1 = (decimal test1 = Math.Round((D1 + tinhDienTichHinhThang(D2, 0, Convert.ToDecimal(timespan3.TotalHours))) * D3, 3, MidpointRounding.AwayFromZero);

输出:test1 = 0.237

如果手动计算:

test1 =  Math.Round((0.25 + ((5+0)*timespan3.TotalHours/2))*0.9, 3, MidpointRounding.AwayFromZero);

输出:test1 = 0.238(确切地说:0.2375)

注意:计算win XP 则准确:0.2375 但计算win 7 则不准确。

请解释一下我为什么和解决这个问题的问题的方式?

4

3 回答 3

1

双精度数是浮点值。它们仍然被限制为 64 位精度,但它们有一个值和一个将值提升到的指数(本质上是科学记数法)。这就是为什么它们的范围比 int 或 long 多,但由于这个扩展的范围,它们不能表示该范围内的所有可能值。

小数的位数比双精度多,因此在转换值时,您只会看到双精度与小数相比精度较低的副作用。

于 2012-12-14T07:37:28.983 回答
0

我不确定你的问题是什么。但是,如果您对十进制和双精度值的不同值有疑问,那是设计使然。默认情况下具有浮点数的数字不精确。

更新:(在答案中回答您的问题)

由于这个问题,您的答案中的第一个和第二个陈述不同:

原因

5M * Convert.ToDecimal(timespan3.TotalHours)/ 2M

计算是十进制的,但以秒为单位:

5 * timespan3.TotalHours / 2

计算是双倍的(因为 timespan3.TotalHours 是双倍的)。这意味着结果可能与第一个语句不同。但是在计算的时候,你将它转换为十进制,它会隐式地将值转换为十进制,这可以改变值。

在第三个语句中,您也有整数值计算,但 double 是浮点类型,因此它的值可以不同于第二个语句,其中定点类型十进制。

于 2012-12-14T07:39:47.200 回答
0
decimal test1 = (0.25M + 5M * Convert.ToDecimal(timespan3.TotalHours) / 2M) * 0.9M;

decimal test2 = (decimal)((0.25 + 5 * timespan3.TotalHours / 2) * 0.9);

double test3 = (0.25 + 5 * timespan3.TotalHours / 2) * 0.9;

何时执行此操作时,它们的以下输出不一样。你能指导解决这个问题吗?

于 2012-12-14T08:19:30.440 回答