岛屿 发表于 2015-1-18 17:14:27

有疑问,求解答。。

printf("%f\n",1.0/3*3);printf("%f\n",3/2); printf("%f\n",1/3*3);与printf("%d\n",1.0/3*3);printf("%d\n",3/2); printf("%d\n",1/3*3);区别

雪是梅之香 发表于 2015-1-18 19:00:02

看了这个,楼主大概会明白了吧,这是网上找的:
float a=7.5f;
      如果用printf("%d",a);输出的是0。
      但float型用%d输出是否一定是0呢,答案肯定不都是0;
      为什么 7.5 用%d输出的是0?分析如下:
      首先来了解下printf的输出格式,int 和 long int 都是32位的,用%d输出;float 、double都是%f输出,但 float 是32位的,double 是64位的,所以在参数传递的时候C语言统一将 float 类型数值传换为 double 类型再传入 printf 函数。如果是32位整型则输出格式为%lld。
      下面来讲一下float a=7.5f ; printf("%d",a)输出为0的情况:
      %d只输出低32位的数据,并将这些32位二进制以十进制数输出,编译器首先将 7.5从float类型转换为double类型,7.5在内存中的存放方式是0x40f00000,转换成double类型在内存中的数据就是这个0x401e000000000000,这个内存数据可以很明显看出低32位全是0,而%d则只能截取到低32位,所以这个以%d输出7.5的数值当然是 0了。如大家不相信可以用%lld 输出看看,这个%lld就很读到低64位数据,读出的结果就是0x401e000000000000,在屏幕上看到一个很大的十进制数。

ANDES 发表于 2015-1-19 11:16:45

%f打印出来的是float类型,可以打印出小数点后面的数。%d打印出的是整型类型,不能打印出小数点后面的数,小数点后面的数会被舍去。

zjc7836 发表于 2015-1-19 21:07:53

这是很基础的问题
页: [1]
查看完整版本: 有疑问,求解答。。