Segmentation violation: while(fgets(buffer,15,statfile)!=NUL

Segmentation violation: while(fgets(buffer,15,statfile)!=NULL){};

本文关键字:statfile NUL buffer violation while fgets Segmentation      更新时间:2023-10-16

如果按顺序寻址 r,则此代码适用于连续数千个调用。如果随机选择 r,它连续工作几百个。

但是,在随机 r 的某个时刻,我得到了分割违规。我不确定是什么原因导致这种情况,因为它几乎一直工作正常。

*** Break *** segmentation violation
Segmentation fault

崩溃发生在fgets。

int fsize(int r, double VME, std::string* filepath) {
  FILE *statfile;
  std::stringstream streamfilename;
  std::stringstream streamcommand;
  string* filename = new string;
  std::string command;
  char buffer [15];
  char charsize;
  streamfilename.str("");
  streamfilename << *filepath << "run" << r << "-" << VME << ".dat";
  *filename = streamfilename.str();
  streamcommand.str("");
  streamcommand << "stat -c " << "%s " << *filename;
  command = streamcommand.str();
  const char * charcommand = command.c_str();
  statfile = popen(charcommand, "r");
  cout << "Test 5n";
  while(fgets(buffer,15,statfile)!=NULL){}; CRASH OCCURS HERE
  cout << "Test 6n";
  int* filesize = new int;
  *filesize = atoi(buffer);
  pclose(statfile);
  return *filesize;
}

分段错误的原因是什么?

statFile可能NULL .

如果你想得到文件大小,你应该考虑C函数:

 int stat(const char *path, struct stat *buf);

它将避免分叉命令并解析其结果。