C# Math.Round()四舍五入、四舍六入五成双

开发者为了实现小数点后 2 位的四舍五入,编写了如下代码,

var num = Math.Round(12.125, 2);

代码非常的简单,开发者实际得到的结果是12.12, 这与其所预期的四舍五入结果12.13相悖。

其实产生这个结果的原因是由于Math.Round 默认使用的并非是四舍五入的原则,而是四舍六入五成双的原则。

四舍六入五成双

所谓的四舍六入五成双,就是说当确定有效位数之后,有效位数的下一位如果小于等于4就舍去,如果大于等于6就进一,当有效位数的下一位是5的时候

如果5前为奇数,就舍五进一

如果5前为偶数,就舍五不进(0是偶数)

从统计学上将,四舍六入五成双比四舍五入要更精确,因为大量计算的情况下,四舍五入逢五进一,会导致结果偏向大数。

例如:

csharp 复制代码
1.15+1.25+1.35+1.45 = 5.2

如果有效位数是小数点后一位,使用四舍五入原则得到的结果

csharp 复制代码
1.2 + 1.3 + 1.4 + 1.5 = 5.4

而使用四舍六入五成双原则得到的结果是

csharp 复制代码
1.2 + 1.2 + 1.4 + 1.4 = 5.2

由此可见四舍六入五成双原则得到的结果更为精确。

Math.Round的四舍五入

那么如何使用Math.Round实现预期的四舍五入呢?

其实C#中的Math.Round提供了非常多的重载方法,其中有两个重载方法是,

csharp 复制代码
public static double Round (double value, int digits, MidpointRounding mode);
public static decimal Round (decimal d, int decimals, MidpointRounding mode);

这两个方法都提供了第三个参数mode, mode是一个MidpointRounding的枚举变量,它有2个可选值

AwayFromZero - 四舍五入

ToEven - 四舍六入五成双

所以如果我们希望的到一个理想中四舍五入的结果,,我们可以改用如下代码:

csharp 复制代码
var num = Math.Round(12.125, 2, MidpointRounding.AwayFromZero);
相关推荐
Sunsets_Red40 分钟前
差分操作正确性证明
java·c语言·c++·python·算法·c#
Aevget1 小时前
DevExpress WPF中文教程:Data Grid - 如何使用虚拟源?(一)
c#·wpf·界面控件·devexpress·ui开发
weixin_456904272 小时前
以太网与工业以太网通信C#开发
开发语言·c#
虚行3 小时前
C#项目连接S7-PLCSIM Advanced读写操作
开发语言·python·c#
“抚琴”的人4 小时前
C#中获取程序执行时间
服务器·前端·c#
薄荷撞~可乐6 小时前
C#拆箱/装箱(性能优化)
性能优化·c#
胖咕噜的稞达鸭6 小时前
C++中的父继子承(2)多继承菱形继承问题,多继承指针偏移,继承组合分析+高质量习题扫尾继承多态
c语言·开发语言·数据结构·c++·算法·链表·c#
Dm_dotnet7 小时前
WPF应用绑定系统快捷键
c#
.NET修仙日记7 小时前
SQL Server实战指南:从基础CRUD到高并发处理的完整面试题库
面试·职场和发展·c#·.net·sql server·.net全栈经典面试题库
武文斌779 小时前
项目学习总结:CAN总线、摄像头、STM32概述
linux·arm开发·stm32·单片机·嵌入式硬件·学习·c#