1215787625 发表于 2023-10-24 08:44:04

为什么数字显示是错的

#include<stdio.h>
int main()
{
        float a;
        double c;
        printf("%f %lf",sizeof(a),sizeof(c));
        return 0;
}

isdkz 发表于 2023-10-24 08:44:42

问题出在你的printf语句中。你使用了错误的格式化字符串来打印浮点数的大小。

在C语言中,"%f"用于打印float类型的变量,而"%lf"用于打印double类型的变量。然而,sizeof函数返回的是变量的字节大小,而不是其值。

要正确打印变量的字节大小,你应该使用"%zu"作为格式化字符串。"%zu"用于打印size_t类型的值,它是sizeof返回的类型。

以下是修正后的代码:

#include <stdio.h>

int main() {
    float a;
    double c;
    printf("%zu %zu", sizeof(a), sizeof(c));
    return 0;
}


这样,你就能正确打印出变量a和c的字节大小了。
页: [1]
查看完整版本: 为什么数字显示是错的