4

现在看来 fseek 至少在我的实现中自然支持大文件,而没有 fseek64、lseek 或一些奇怪的编译器宏。

这是什么时候的事儿?

#include <cstdio>
#include <cstdlib>
void writeF(const char*fname,size_t nItems){
  FILE *fp=NULL;
  if(NULL==(fp=fopen(fname,"w"))){
    fprintf(stderr,"\t-> problems opening file:%s\n",fname);
    exit(0);
  }
  for(size_t i=0;i<nItems;i++)
    fwrite(&i,sizeof(size_t),1,fp);
  fclose(fp);
}
void getIt(const char *fname,size_t offset,int whence,int nItems){
  size_t ary[nItems];
  FILE *fp = fopen(fname,"r");
  fseek(fp,offset*sizeof(size_t),whence);
  fread(ary,sizeof(size_t),nItems,fp);

  for(int i=0;i<nItems;i++)
    fprintf(stderr,"%lu\n",ary[i]);
  fclose(fp);
}


int main(){
  const char * fname = "temp.bin"; 
  writeF(fname,1000000000);//writefile
  getIt(fname,999999990,SEEK_SET,10);//get last 10 seek from start
  getIt(fname,-10,SEEK_END,10);//get last 10 seek from start
  return 0;
}

上面的代码以二进制 size_t 格式写入一个包含条目 1-10^9 的大文件。然后写入最后 10 个条目,从文件开头查找,从文件末尾查找。

4

3 回答 3

1

Linux x86-64 从一开始就支持大文件(LFS);并且不需要任何特殊的宏等来启用它 - 传统的fseek())和 LFSfseek64()已经使用 64 位off_t

Linux i386(32 位)通常默认为 32 位off_t,否则会破坏大量应用程序 - 但您可以通过检查_FILE_OFFSET_BITS宏的值来测试环境中定义的内容。

有关Linux 大文件支持的完整详细信息,请参见http://www.suse.de/~aj/linux_lfs.html 。

于 2011-07-07T19:48:30.713 回答
1

签名是

int fseek ( FILE * stream, long int offset, int origin );

所以范围取决于 的大小long

在某些系统上它是 32 位的,而您在处理大文件时会遇到问题,而在其他系统上它是 64 位的。

于 2011-07-07T20:13:14.723 回答
0

999999990是一个普通的 int 并且完全适合 32 位。我不相信你会逃脱这个虽然:

getIt(fname,99999999990LL,SEEK_SET,10);
于 2011-07-07T19:27:41.580 回答