关于c语言double

为什么在c语言中类型为double时输出用f输入却是lf,int时输入输出都是d,而double时为什么输入输出不一样呢?... 为什么在c语言中类型为double时输出用f 输入却是lf, int时输入输出都是d,而double时为什么输入输出不一样呢? 展开
 我来答 举报
语多放肆
2015-01-09 · TA获得超过156个赞
知道小有建树答主
回答量:122
采纳率:75%
帮助的人:90.7万
展开全部
这个问题很复杂。想了解需要很多的知识。现在的C语言(ANSIC、C99等)不会把表达式或者参数的float转成double类型,但是printf函数会。它的参数没有float类型,只有double类型(实际上是变长参数,什么类型也没有,这事情说起来就复杂了,牵涉到printf的实现),所以printf只能接收double型的参数(或者说,他只认出来double型),对应输入的占位符只有%f一个。但是scanf却不一样,它的参数可以是double的指针,可以是float的指针(注意它们都是指针,怎么解释就需要占位符来指明),所以就有%f和%lf的区别。
顺便说一下,在C99标准中,printf中的%lf和%f是完全一样的,没有任何精度区别。printf是无法区分是double 还是float的,因为它是变长参数,float永远会被提升成为double,和没有原型的函数参数一样。
J哥谈近视
2015-01-08 · 专注近视防控和视觉矫正
J哥谈近视
采纳数:325 获赞数:1483

向TA提问 私信TA
展开全部
C编译系统对double型数据分配8个字节,说以习惯上输入用%lf格式以确保存储精度
而输出的时候没有强制说用%f,同样也是出于习惯,在大部分数据都是float型的时候,用%f输出也是无妨的,但最好用%lf输出,这样在精度保留上最保险。
抢首赞 已赞过 已踩过<
你对这个回答的评价是?
评论 举报 收起
王勃啊
2015-01-08 · TA获得超过1.1万个赞
知道大有可为答主
回答量:5015
采纳率:62%
帮助的人:4079万
展开全部
double输出应该是lf 的。。。只是用f也可以罢了。
抢首赞 已赞过 已踩过<
你对这个回答的评价是?
评论 举报 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式