有个段代码如下:
#include<stdio.h>
int main()
{
printf("%f\n",5);
printf("%d\n",5.01);
return 0;
}
咋一看,很简单,但实际上考察了我们对printf函数、数据类型以及浮点数在内存中的表示等等知识,其实不简单。
【答案】
0.000000
1889785610(一个很大的数)
【解释】
第一个中printf根据说明符%f认为参数应该是一个double型(printf中float会自动转换成double型),因此从stack中读取了8个字节,而stack中事先只分配了4个字节用于存放int型数字5,所以会出现内存访问越界的问题。
第二个中由于5.01是浮点数,在内存中会分配4个字节以float的格式存储数据,而输出的时候是按int的格式输出的,所以会出现一个很大的整数的情况。至于float在内存中的表示方法,大家可以参考网上的帖子。
【疑问】
第一个输出为什么是0.000000?内存越界应该来说输出的是一个不确定的数才对呀?