[英]Reading and writing double precision from/to files
我试图将双数组写入文件并再次读取它们。 下面是我的代码,但是我缺少一些东西。 听起来很愚蠢,但我做对了。
#include <stdio.h>
#include <stdlib.h>
int main(){
int i,j,k;
int N = 10;
double* readIn = new double[N];
double* ref = new double[N];
FILE* ptr1, *ptr2;
ptr1 = fopen("output.txt","w");
//write out
for (i = 0; i < N;i++){
ref[i] = (double)i;
fprintf(ptr1,"%g\n",(double)i);
}
fclose(ptr1);
//read file
ptr2 = fopen("output.txt","r+");
//read in
for(i = 0;i < N;i++)
fscanf(ptr2, "%g", &readIn[i]);
fclose(ptr2);
for(i = 0;i<N;i++)
if(ref[i] != readIn[i]){
printf("Error: %g %g\n",ref[i], readIn[i]);
}
return 0;
}
您的fscanf
使用了错误的格式字符串(GCC会告诉您是否启用了足够的警告)。
因此,您的double
填充有float
值,这当然会导致相当“随机”的错误。
如果将"%g"
更改为"%lg"
,它应该可以正常工作(至少在我的Linux机器上可以)。
当然,如果您使用C ++流,例如
#include <fstream>
std::ofstream file1;
std::ifstream file2;
file1.open("output.txt");
for (i = 0; i < N;i++){
ref[i] = (double)i;
file1 << (double)i << std::endl;
}
和
file2.open("output.txt");
for(i = 0;i < N;i++)
file2 >> readIn[i];
整个问题都可以避免-如果将readIn
变量编辑为float
,只要该值对它是有效的,就可以读取这些值而无需更改其他任何内容[假设输出也使用cout
代替的printf,当然]。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.