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
以上的保留都采起了四舍五入的处理。