有疑问,求解答。。
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);区别看了这个,楼主大概会明白了吧,这是网上找的:
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,在屏幕上看到一个很大的十进制数。 %f打印出来的是float类型,可以打印出小数点后面的数。%d打印出的是整型类型,不能打印出小数点后面的数,小数点后面的数会被舍去。 这是很基础的问题
页:
[1]