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


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