您的位置:首页 > 编程语言 > C语言/C++

关于C语言中printf函数的一个问题

2008-08-19 10:55 477 查看
对于下面的程序,我用VS2003运行的结果第一个是0,第二个是一个很大的数。
#include <stdio.h>
int main()
{
printf("%f",5); //line 1
printf("%d",5.01); //line 2
}

具体原因在论坛上提问后得到结果。引用答案如下

关键你要理解浮点数的存储格式!

printf("%f",5); //line 1
5在内存中是 0x00 00 00 05,按照float格式解释是一个无限接近于0的浮点数数

printf("%d",5.01); //line 2
5.01按照整数去解释,这个数应该是一个非常大的整数

帮1楼补充几句:
这是printf可变参数不做类型检查引起的。
int printf(const char *format, ...);

printf("%f",5); //line 1
编译器在给printf传参的时候,不知道这个5应该传什么类型,所以只能按1楼所说整数的格式传进去。在printf里面使用这个参数的时候却是按照"%f"的要求解释成了浮点数。
前面的"%f"对编译器来说就是一个普通字符串而已,编译器不懂printf的格式。
所以可变参数的函数是很危险的,尽量少用。

如果是一个普通的函数,编译器就会根据函数原型,在传参的时候自动做类型转换。
比如
void foo(float f);
......
foo(5);
在这里编译器知道foo需要一个浮点数,事先就会把5转换成浮点数的格式传进去。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: