繁体   English   中英

读写文件的双精度

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM