助けて。
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 のタイプを使用する場合:
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 を計算すると正確ではありません。
なぜこの問題をどのように解決するのかという問題を解釈してください。