C#中double类型保留小数点后两位

C#语言的double类型占用8字节,代码中的常数是小数形式,默认是double类型。float赋值给double类型,自动转为doule类型。double类型的小数位默认最少一位,若是小数位数后有多余的0自动把多余的0去掉。例如:ide

double dTest = 1234;//此时dTest的值为1234.0;dTest = 1.00;//此时dTEst的值为1.0;ci

若是调用 dTest.ToString();获得的字符串为1234,自动把小数位末尾的0省略。除非指定格式,详情以下:字符串


程序代码string

string myStr = dTest.ToString("0.00");it


若是要返回double类型能够执行下面语句:class

double myDou = double.Parse(dTest.ToString("0.00"));float


固然了也能够用 Math.Round方法程序

decimal myDec = Math.Round(dTest,2); 后面的2表示保留小数点后2位小数方法


若是要把一个非double类型的值保留指定小数位数,通常先转化为double类型而后转化为指定格式的字符串。一下例子可说明该问题。im


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


以上的保留都采起了四舍五入的处理。

相关文章
相关标签/搜索