码迷,mamicode.com
首页 > Windows程序 > 详细

C#中Math.Round() 的真实含义

时间:2018-02-11 14:44:39      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:语言   rom   算法   应该   hive   archive   .com   t-sql   html   

今天踩了一个坑
Math.Round()函数取四舍五入发现不对,3/2 = 2, 5/2 = 2
网上搜了一下:http://www.cnblogs.com/fanyong/archive/2013/05/30/chinese_round.html

C#中的Math.Round()并不是使用的"四舍五入"法。其实在VB、VBScript、C#、J#、T-SQL中Round函数都是采用Banker‘s rounding(银行家算法),即:四舍六入五取偶。事实上这也是IEEE的规范,因此所有符合IEEE标准的语言都应该采用这样的算法。

.NET 2.0 开始,Math.Round 方法提供了一个枚举选项 MidpointRounding.AwayFromZero 可以用来实现传统意义上的"四舍五入"。即: Math.Round(4.5, MidpointRounding.AwayFromZero) = 5。

C#中Math.Round() 的真实含义

标签:语言   rom   算法   应该   hive   archive   .com   t-sql   html   

原文地址:https://www.cnblogs.com/shuoli/p/8440906.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!