首页 > 解决方案 > 我的函数返回错误的双精度值 (C)

问题描述

所以我的代码相对简单,我只是试图从文件(input.dat)中获取双精度。我得到了双倍,但是当我回到 main 时,由于某种原因,我得到了不同的值。这是代码:

int main(void) {

    FILE *infile;

    infile = fopen("input.dat", "r");

    double data = read_double(infile);
    printf("%lf", data);
    return 0;
}

double read_double(FILE *infile) {

    double data = 0;
    //infile = fopen("input.dat", "r");
    fscanf(infile, "%lf", &data);
    printf("%lf\n", data);
    return data;
}

input.dat 中的实际内容

11234567.0

所以当我运行程序时,read_double 中的 print 语句正在打印正确的数字。但是当我将它返回给 main 并在 main 中打印时,它会打印到 16.000。

当我摆脱 read_double 中的打印语句时,main 打印 1.000。我现在真的不知道该怎么办,我想知道这是否与数据存储和传输的方式有关?任何帮助表示赞赏,谢谢。

标签: c

解决方案


您需要在定义 main() 的源文件或包含的标头中声明 read_double() 函数的返回类型。否则,C 不“知道”它返回浮点双精度类型。

double read_double(FILE *infile);

int main(void) { ....

推荐阅读