问题描述:
C语言里,double类型的数据可以精确到小数点后几位?
Linux32位环境下,C语言,gcc编译的,不是说double是精确到16位的吗,但我这里只显示了6位,double a=1.0000019;printf(“%lf”,a),输出1.000001;再多一位就直接自动四舍五入了,初学者求助.
问1:为什么只显示了6位,而不是书上说的16位?
问2:为什么会自动四舍五入,如何不让他四舍五入?
Linux32位环境下,C语言,gcc编译的,不是说double是精确到16位的吗,但我这里只显示了6位,double a=1.0000019;printf(“%lf”,a),输出1.000001;再多一位就直接自动四舍五入了,初学者求助.
问1:为什么只显示了6位,而不是书上说的16位?
问2:为什么会自动四舍五入,如何不让他四舍五入?
问题解答:
我来补答展开全文阅读