(C语言中printf函数读取的具体分析)

(C语言中printf函数读取的具体分析)

不多说,直接上。printf函数将传入的数据传送到内存堆区(缓冲区),然后再根据前面的(格式说明符一个个读取,这样会造成错误)


#include<stdio.h>
#include<limits.h>
#include<float.h>
int main(void)
{
    float n1 = 1.342;
    double n2 = 3.145;
    int n3 = 4321 ,n4 = 1234;
    printf("%ld %ld %ld %ld",n1,n2,n3,n4);
}

   

结果是在这里插入图片描述
在这里插入图片描述
n3,n4本是浮点型,结果却输出的值却是n1呢
的值。这是因为堆空间。

printf 函数在取出来堆空间里的函数值时,在取的时候,先把n1,n2 取出,(float 虽然为4字节,但在处理过程中c编译器把它看作8字节),二者虽然为float,double 类型,但是取出的时候是%ld 四字节出去的。所以n1 取到n4的值,n2 取得n1的值, n3取得n2前四字节的值,n4取得n2后四字节的值。

猜你喜欢

转载自blog.csdn.net/weixin_43276867/article/details/84931489