0

我有一个while循环,我正在从存档文件中读取并提取第一个文件。

  int fd = open(argv[2], O_RDWR | O_CREAT, 0666);
  char name_buffer[16];
  char size_buffer[10];

  // go to the first header
  lseek(fd, SARMAG, SEEK_CUR);

  // store the number of bits read in a struct current_header
  // until its size equal to the size of the entire
  // header, or in other words, until the entire
  // header is read
  while ((num_read = read(fd, (char*) &current_header, 
    sizeof(struct ar_hdr))) == sizeof(struct ar_hdr))
  {

    // scans the current string in header and stores
    // in nameStr array
    sscanf(current_header.ar_name, "%s", name_buffer);
    sscanf(current_header.ar_date, "%s", date_buffer);
    sscanf(current_header.ar_uid, "%s", uid_buffer);
    sscanf(current_header.ar_gid, "%s", gid_buffer);

    int mode;
    sscanf(current_header.ar_mode, "%o", &mode);
    sscanf(current_header.ar_size, "%s", size_buffer);
    sscanf(current_header.ar_fmag, "%s", fmag_buffer);

    new_file_fd = open(name_buffer, O_WRONLY | O_CREAT | O_TRUNC);
    int size = atoi(size_buffer);
    char buf[size];
    size_t count = size;

    while ((n_read = read(fd, buf, size)) > 0)
    {
      n_write = 0;
      do {
        n = write(new_file_fd, &buf[n_write], n_read - n_write);
        n_write += n;
      } while (n_write < n_read);

    }
    close(new_file_fd);
   }
   lseek(fd, size + (size%2), SEEK_CUR);

对于具有以下结构的给定存档文件:

!<arch>
File1             1382142494  501   20    100644  29        `
Testing 123

File2             1382142504  501   20    100644  23        `
Testing 246

预期的输出应该是仅包含内容“Testing123”的文件“File1”。相反,我得到 File1 的内容:Testing 123

File2             1382142504  501   20    100644  23        `
Testing 246

出于某种原因,即使我已经指定了要读取和写入的位数(参数 3 是“大小”,它返回 29——File1 的大小),它仍然会持续读取和写入超过 29 个字节。

任何想法为什么会发生这种情况?

4

1 回答 1

1

while ((n_read = read(fd, buf, size)) > 0)

您需要在循环中更新大小。

size -= n_read

否则,您将继续循环,直到到达文件末尾。您需要循环调用 read() 的原因只是它不保证它会在第一次调用时读取指定的字节数,它只保证它不会超过那个。所以你需要继续调用它,直到你读完所有你想要的字节。但是您确实需要更新 bytes 参数,因为否则文件描述符fd将继续前进到文件末尾。

于 2013-10-19T15:15:43.177 回答