zoukankan      html  css  js  c++  java
  • 【疑问】有关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?内存越界应该来说输出的是一个不确定的数才对呀?

  • 相关阅读:
    java入门了解14
    java入门了解13
    java入门了解12
    java入门了解11
    Hive-安装
    Hive-基本概念
    Java笔记20
    Java-笔记19
    Java-笔记18-复习
    Java-笔记18
  • 原文地址:https://www.cnblogs.com/hust_wsh/p/2216840.html
Copyright © 2011-2022 走看看