C# 怎么把double 存成两位精度小数

本文介绍了C#语言中Double类型的使用方法,包括其默认的行为、如何保留指定小数位数以及通过不同方式实现数值格式化的技巧。

C#语言的double类型占用8字节,代码中的常数是小数形式,默认是double类型。float赋值给double类型,自动转为doule类型。double类型的小数位默认最少一位,如果小数位数后有多余的0自动把多余的0去掉。例如:
double dTest = 1234;//此时dTest的值为1234.0;dTest = 1.00;//此时dTEst的值为1.0;
如果调用 dTest.ToString();得到的字符串为1234,自动把小数位末尾的0省略。除非指定格式,详情如下:

程序代码
string myStr = dTest.ToString("0.00");

如果要返回double类型可以执行下面语句:
double myDou = double.Parse(dTest.ToString("0.00"));

当然了也可以用 Math.Round方法
decimal myDec = Math.Round(dTest,2); 后面的2表示保留小数点后2位小数

如果要把一个非double类型的值保留指定小数位数,一般先转化为double类型然后转化为指定格式的字符串。一下例子可说明该问题。

int myTest1 = 10000;
string myTest2= "10000";
string myTest3= "10000.12345";
string myTest4= "10000.1289"

Convert.ToDouble(myTest1).ToString("0.00");//保留小数点后两位,结果为10000.00
Convert.ToDouble(myTest2).ToString("0.00");//保留小数点后两位,结果为10000.00
Convert.ToDouble(myTest3).ToString("0.00");//保留小数点后两位,结果为10000.12
Convert.ToDouble(myTest4).ToString("0.00");//保留小数点后两位,结果为10000.13

以上的保留都采取了四舍五入的处理。
资源下载链接为: https://pan.quark.cn/s/9e7ef05254f8 在C#编程中,decimal类型常用于财务和货币计算,因其精度高于float和double。有时需将decimal值精确保留至指定小数位,如2位有效小数。以下是三种实现方式: Math.Round方法:此方法可对数字进行四舍五入。针对decimal类型,可使用Math.Round(decimal d, int decimals),其中decimals指定保留小数位数。例如: 这会使numDecimal四舍五入为34.35。 ToString方法:可先将decimal转为字符串,再转回。在转为字符串时,通过指定格式保留小数位数。例如: 格式字符串"#0.00"确保结果有2位小数,即使尾部为零,numDecimal最终为34.35。 String.Format方法:此方法用于格式化输出,也可保留小数位数。例如: 标准格式字符串"{0:N}"按当前文化信息格式化数值,通常含千分位分隔符和2位小数,numDecimal会被四舍五入为34.35。 此外,decimal类型通过ToString配合自定义格式字符串可保留小数点后有效数字。如d.ToString("0.##")会去掉多余0,仅保留最多2位非零小数。若d = 0.5000M,则结果为"0.5"。 在处理decimal值时,选择何种方法取决于需求。若需保持数值类型并运算,Math.Round较合适;若需输出或储,ToString和String.Format更灵活。但需注意,四舍五入可能改变原始值精确度,尤其在值接近边界时。金融计算中,应谨慎处理舍入误差。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值