scanf("%lf", &i);与scanf("%f", &i);的区别

azhen 2005-11-08 08:55:14
我写了这样一个程序
double i;
scanf("%f", &i);
printf("%f", i);
如果我输入的是5,为什么输出的是0.0000呢?
如果使用scanf("%lf",&i);可以得到正确的结果,为什么呢?
...全文
3454 12 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
azhen 2005-11-09
  • 打赏
  • 举报
回复
能不能从内存分配上面解释这个现象呢?
我不太明白scanf("%f");和scanf("lf")内存是怎么分配的?
一般情况下,float是分配4个单元的内存,double是分配8个单元的内存
但这些内存里面是有哪些部分分配给小数部分,哪些给指数部分呢?
richu 2005-11-09
  • 打赏
  • 举报
回复
厉害。又学了一招。
  • 打赏
  • 举报
回复
这么细心啊,强
newbiestar 2005-11-09
  • 打赏
  • 举报
回复
这个……楼主需要去参考IEEE754浮点规范了

简单点说,float是1位符号,8位阶码,23位有效数字;double是1位符号,11位阶码,52位有效数字

你这个如果用gcc的-Wall参数来进行编译的话,gcc其实是会给你提示你搞错了的……
> cat float_scanf.c
#include <stdio.h>

int main(void)
{
double val;
scanf("%f", &val);
}
> gcc -Wall float_scanf.c
float_scanf.c: In function `main':
float_scanf.c:6: warning: float format, double arg (arg 2)
float_scanf.c:7: warning: control reaches end of non-void function
Ksion2005 2005-11-08
  • 打赏
  • 举报
回复
向你们学习
Mr_Yang 2005-11-08
  • 打赏
  • 举报
回复
up
shellzie 2005-11-08
  • 打赏
  • 举报
回复
精度不一样
bombwang 2005-11-08
  • 打赏
  • 举报
回复
学习
m0792 2005-11-08
  • 打赏
  • 举报
回复
确切的说输出的是一个小数点后有6位的双精度型数据吧,就象x.000 000

skfox 2005-11-08
  • 打赏
  • 举报
回复
类型不匹配,我在vc6.0的环境下都是一堆乱七八糟的数据
用%d就可以了
sankt 2005-11-08
  • 打赏
  • 举报
回复 1
%f 对应的是float
%lf 对应的是double
llf_hust 2005-11-08
  • 打赏
  • 举报
回复
double i;//因为i是double类型,必须要用%lf格式

70,021

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧