#include<stdio.h> int main() { float a=10.0f; printf("%d\n",a); } 这个程序的输出结果为什么为0?

 我来答
龍__鳳
2013-08-30 · TA获得超过2346个赞
知道小有建树答主
回答量:948
采纳率:0%
帮助的人:1415万
展开全部
#include<stdio.h> 
int main()

float a=10.0f;
printf("%d\n",a);//你的输出格式是%d
printf("%f\n",a);
printf("%d\n",(int)a);//想输出10的话要强制转换
}

 

追问
我想知道printf("%d\n",a);输出为什么是0?
追答
你把10.0在内存用IEEE标准存储,float按照%d输出,会去前4个字节,你按IEEE标准写出来10.0的存储形式,去前四个字节,就知道了
金色潜鸟
2013-08-31 · TA获得超过3.2万个赞
知道大有可为答主
回答量:1.3万
采纳率:89%
帮助的人:5787万
展开全部
C/C++ 规定 输出输入格式 要与 变量类型 匹配。float 不能 用 %d 格式输出。
不管你 a=10.0, a=20.0 用 %d 输出 就是 0。没什么 道理。

用联合体可以洞悉内存字节里的内容
union U{
float a;
int b;
char c[4];
} u;
main(){
u.a = 10.0; // 用 12.0 20.0 ....
printf("c= %x %x %x %x\n",u.c[0],u.c[1],u.c[2],u.c[3]);
printf("b= 0x%x\n",u.b);
printf("b= %d\n",u.b);
printf("a=%f\n",u.a);
printf("a=%d\n",u.a); // 打印 0
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
是经费和
2013-08-30 · TA获得超过1648个赞
知道小有建树答主
回答量:1584
采纳率:0%
帮助的人:741万
展开全部
这跟具体的数字在内存中的表示方式有关.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式