【疑问】有关C语言中printf函数的输出和格式的问题

有个段代码如下:

#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?内存越界应该来说输出的是一个不确定的数才对呀?