C# 中Math.Round()、ToString()四舍五入的细节

博客内容为总结,但未给出具体总结信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

double db = 4.25;
Console.WriteLine(Math.Round(db, 1));//4.2
Console.WriteLine(db.ToString("0.0"));//4.3
db = 4.35;
Console.WriteLine(Math.Round(db, 1));//4.4
Console.WriteLine(db.ToString("0.0"));//4.4
db = 4.251;
Console.WriteLine(Math.Round(db, 1));//4.3
Console.WriteLine(db.ToString("0.0"));//4.3

总结

Math.Round() 四舍六入五凑偶
ToString() 四舍五入
C# 中实现四舍五入有多种方法,这些方法适用于不同的场景和精度需求。以下是几种常见的实现方式: ### 使用 `Math.Round` 方法 `Math.Round` 是 C# 中最常用的四舍五入方法,它默认采用银行家舍入法(即对中间值进行舍入时,向最近的偶数舍入)。如果需要传统的四舍五入逻辑,可以指定 `MidpointRounding.AwayFromZero` 参数。 示例: ```csharp double value = 3.45; double roundedValue = Math.Round(value, 1, MidpointRounding.AwayFromZero); Console.WriteLine(roundedValue); // 输出 3.5 ``` ### 使用字符串格式化 字符串格式化可以将数值转换为特定格式的字符串,适用于显示需求。需要注意的是,格式化操作通常用于输出,而不是计算。 示例: ```csharp double value = 3.45; string formattedValue = value.ToString("F1"); Console.WriteLine(formattedValue); // 输出 3.5 ``` ### 使用 `Decimal.Round` 方法 `Decimal.Round` 方法适用于高精度数值计算,例如财务数据处理。它提供了与 `Math.Round` 类似的功能,但更适合处理 `decimal` 类型数据。 示例: ```csharp decimal value = 3.45m; decimal roundedValue = Decimal.Round(value, 1, MidpointRounding.AwayFromZero); Console.WriteLine(roundedValue); // 输出 3.5 ``` ### 使用自定义的四舍五入逻辑 对于特殊需求,可以实现自定义的四舍五入逻辑。例如,可以编写一个函数来处理特定的舍入规则。 示例: ```csharp public static double CustomRound(double value, int decimalPlaces) { double multiplier = Math.Pow(10, decimalPlaces); return Math.Floor(value * multiplier + 0.5) / multiplier; } double value = 3.45; double roundedValue = CustomRound(value, 1); Console.WriteLine(roundedValue); // 输出 3.5 ``` ### 使用 LINQ 和 IEnumerable 扩展方法 对于集合数据的处理,可以通过 LINQ 和扩展方法对每个元素进行四舍五入操作。 示例: ```csharp List<double> values = new List<double> { 3.45, 2.55, 5.65 }; List<double> roundedValues = values.Select(v => Math.Round(v, 1, MidpointRounding.AwayFromZero)).ToList(); foreach (var value in roundedValues) { Console.WriteLine(value); } // 输出 3.5, 2.6, 5.7 ``` ### 总结 C# 提供了多种四舍五入方法,开发者可以根据具体需求选择合适的方式。例如,`Math.Round` 适用于常规数值计算,而 `Decimal.Round` 更适合财务数据处理。对于复杂场景,可以实现自定义逻辑或使用 LINQ 处理集合数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值