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

Linux32位环境下,C语言,gcc编译的,不是说double是精确到16位的吗,但我这里只显示了6位,double a=1.0000019;printf(“%lf”,a),输出1.000001;再多一位就直接自动四舍五入了,初学者求助。
问1:为什么只显示了6位,而不是书上说的16位?
问2:为什么会自动四舍五入,如何不让他四舍五入?

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)。          

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-12-16
C语言里面,默认%f是小数点后6位,如果想小数点后面16位,写成%.16lf
不会自动四舍五入的,double是一个近似值,通常没有办法做的很精确.
通常能精确到小数点后面5,6位,也就是说超过5,6位了可能就不准了。本回答被提问者采纳
第2个回答  2013-08-22
"%lf"默认只显示6位小数,如果想显示更多请指定:例如"%0.16lf"
精度位不够自动四舍五入,没办法去掉。只有增加精度显示
第3个回答  2013-08-22
十进制的15或16位有效数字,因此精确到小数点后最多有15或16位。
第4个回答  2013-08-22
这个我记得跟系统的位数有关吧,还有你是以lf 的格式打印出来的,这2个一样吗?
相似回答