C语言里,double类型的数据可以精确到小数点后几位?

2024-11-30 04:19:14
推荐回答(5个)
回答1:

C语言里面,默认%f是小数点后6位,如果想小数点后面16位,写成%.16lf,不会自动四舍五入的,double是一个近似值,通常没有办法做的很精确。通常能精确到小数点后面5,6位,也就是说超过5,6位了可能就不准了。

1、double f = 111231.5585; BigDecimal b = new BigDecimal(f); double f1 = b.setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue(); 。

2、new java.text.DecimalFormat("#.00").format(3.1415926)

3、C风格,最方便,double d = 3.1415926;String result = String .format("%.2f", d); String .format("%-10.2f", d); 

4、NumberFormat ddf1=NumberFormat.getNumberInstance() ; void setMaximumFractionDigits(int digits)。          

回答2:

C语言里面,默认%f是小数点后6位,如果想小数点后面16位,写成%.16lf
不会自动四舍五入的,double是一个近似值,通常没有办法做的很精确.
通常能精确到小数点后面5,6位,也就是说超过5,6位了可能就不准了。

回答3:

"%lf"默认只显示6位小数,如果想显示更多请指定:例如"%0.16lf"
精度位不够自动四舍五入,没办法去掉。只有增加精度显示

回答4:

十进制的15或16位有效数字,因此精确到小数点后最多有15或16位。

回答5:

这个我记得跟系统的位数有关吧,还有你是以lf 的格式打印出来的,这2个一样吗?