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