在c#的数字运算过程中,有时候针对十进制decimal类型的计算需要保留2位有效小数,针对decimal变量保留2位有效小数有多种方法,可以使用math.round方法以及tostring先转换为字符串等操作来实现。

(1)方法一:使用c#中的数字计算类math类中的方法math.round方法。

math.round方法是用于计算四舍五入的方法,其中一个方法签名为decimal round(decimal d, int decimals),d代表要进行计算的decimal变量,decimals代表保留的小数位数。

例如有个decimal类型变量numdecimal=34.3471,需要对之保留2位有效数字可使用下列语句:

 decimal numdecimal = 34.3471m;
 numdecimal = math.round(numdecimal, 2);

计算结果为:34.35,math.round方法进行了四舍五入操作。

(2)方法二:先使用tostring转换为字符串,再转换回decimal类型。

使用该办法的时候,调用tostring方法也会进行四舍五入操作。

继续方法一中的例子,如果使用tostring方法,可使用下列程序语句:

 decimal numdecimal = 34.3471m;
string numdecimalstr = numdecimal.tostring(“#0.00”);
numdecimal = decimal.parse(numdecimalstr);

计算结果为:34.35,tostring(“#0.00”)对计算结果转换为字符串进行了四舍五入操作。

(3)方法三:先使用string.format方法格式化decimal类型为字符串,而后在转换为decimal类型。

使用该办法的时候,同样会像上面2个方法一样,对计算结果进行四舍五入。

继续方法一中的例子,如果使用string.format方法,可使用下列程序语句:

decimal numdecimal = 34.3471m;
string numdecimalstr = string.format(“{0:n}”, numdecimal);
numdecimal = decimal.parse(numdecimalstr);

备注:原文转载自博主个人站it技术小趣屋,原文链接为c#中decimal保留2位有效小数_it技术小趣屋。