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

Linux32位环境下,C语言,gcc编译的,不是说double是精确到16位的吗,但我这里只显示了6位,doublea=1.0000019;printf(“%lf”,a... Linux32位环境下,C语言,gcc编译的,不是说double是精确到16位的吗,但我这里只显示了6位,double a=1.0000019;printf(“%lf”,a),输出1.000001;再多一位就直接自动四舍五入了,初学者求助。
问1:为什么只显示了6位,而不是书上说的16位?
问2:为什么会自动四舍五入,如何不让他四舍五入?
展开
 我来答
WW52323
2018-03-31 · TA获得超过9115个赞
知道小有建树答主
回答量:25
采纳率:100%
帮助的人:2601
展开全部

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

cooke1234
推荐于2017-12-16 · TA获得超过6859个赞
知道大有可为答主
回答量:4617
采纳率:72%
帮助的人:3446万
展开全部
C语言里面,默认%f是小数点后6位,如果想小数点后面16位,写成%.16lf
不会自动四舍五入的,double是一个近似值,通常没有办法做的很精确.
通常能精确到小数点后面5,6位,也就是说超过5,6位了可能就不准了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Roxxette
2013-08-22 · TA获得超过828个赞
知道小有建树答主
回答量:1341
采纳率:0%
帮助的人:796万
展开全部
"%lf"默认只显示6位小数,如果想显示更多请指定:例如"%0.16lf"
精度位不够自动四舍五入,没办法去掉。只有增加精度显示
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2013-08-22
展开全部
十进制的15或16位有效数字,因此精确到小数点后最多有15或16位。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
shiyisai123456
2013-08-22 · 超过12用户采纳过TA的回答
知道答主
回答量:46
采纳率:0%
帮助的人:17.9万
展开全部
这个我记得跟系统的位数有关吧,还有你是以lf 的格式打印出来的,这2个一样吗?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式