0

我正在使用 libbzip2 指令按照 bzip2 编程来制作压缩/解压缩脚本,但我在阅读步骤中遇到了问题。这是我的代码:

int decode = (argv[4][0]=='d');
 FILE* f = fopen( argv[2], "rb" ); if( f==0 ) return 2;
 FILE* g = fopen( argv[3], "wb" ); if( g==0 ) return 2;
 int bzError;
 int nBuf;
 int f_len = flen(f);
 byte* inp = new byte[f_len*4+1024*1024];   if( inp==0 ) return 3;

 
 f_len = fread( inp, 1,f_len, f );
 
 if( decode==0 ) {
   int BLOCK_MULTIPLIER = atoi( argv[5] );
   BZFILE *myBZ = BZ2_bzWriteOpen(&bzError, g, BLOCK_MULTIPLIER, 0, 0);
   BZ2_bzWrite(&bzError, myBZ, inp, f_len);
   BZ2_bzWriteClose(&bzError, myBZ, 0, NULL, NULL);
   
  } else {
   byte buf[4096];
   
   BZFILE *myBZ = BZ2_bzReadOpen(&bzError, f, 0, 0, NULL, 0);
   if (bzError != BZ_OK) {
      fprintf(stderr, "E: BZ2_bzReadOpen: %d\n", bzError);
      return -1;
   }

   while (bzError == BZ_OK) {
      int nread = BZ2_bzRead(&bzError, myBZ, buf, sizeof buf);
      cout<<"nread= "<<nread<<"\n";
      if (bzError == BZ_OK || bzError == BZ_STREAM_END) {
         size_t nwritten = fwrite(buf, 1, nread, stdout);
         if (nwritten != (size_t) nread) {
            fprintf(stderr, "E: short write\n");
            return -1;
  }
}

}

   if (bzError != BZ_STREAM_END) {
      fprintf(stderr, "E: bzip error after read: %d\n", bzError);
      return -1;

}

   BZ2_bzReadClose(&bzError, myBZ);
   return 0;

}

压缩模式工作正常,但如果它处于解压缩模式,bzRead 步骤将失败,我从错误消息/语句中得到以下输出:

nread = 0 E: 读取后 bzip 错误:-7

为什么nread会是0?此外,-7 代表一个意外的 EOF,但这怎么可能呢?我也尝试在使用内置 linux bzip2 压缩的文件上运行它,并获得相同的输出。

4

1 回答 1

0

看起来您在决定是否解码之前正在阅读整个输入文件。如果是,那么即使您已经到达文件的末尾,您也会尝试继续读取同一个输入文件。所以你什么也得不到。

于 2020-08-06T04:47:49.160 回答