从文件到文件的读写,直到linux下的c中的EOF

时间:2013-10-22 07:08:33

标签: c linux

我在c中有这个代码来打开文件并将其内容写入另一个文件,但是当我运行它时错误的结果和一些行只被复制并进入无限循环:

#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <errno.h>


//static int    read_cnt;
//static char   *read_ptr;
//static char   read_buf[1024];


int main(int argc, char **argv)
{
    //i have a variable size which is an int and is the byte size of the file
    //i got the byte size of file from stat
    int fileread = open("/tmp/des.py",'r');
    char buffer[1024];



    while((fileread = read(fileread, buffer, sizeof(buffer))>0));
    {
        if(fileread < 0) 
              printf("error write");
    }


    int filewrite = open("/tmp/original.txt", O_WRONLY|O_CREAT);

    while ((filewrite = write(filewrite, buffer, sizeof(buffer))>0))
    {
        if(filewrite < 0)
              printf("error write");
    }


    close(filewrite);
    close(fileread);

    return 0;
}

所以如何解决这个问题

3 个答案:

答案 0 :(得分:1)

在本声明中

    while(   (fileread=read(fileread,buffer,sizeof(buffer))>0));

你用读取的字节数覆盖fileread的值,这是一个文件句柄。代码应该是

    int bytesRead = 0;
    while(   (bytesRead=read(fileread,buffer,sizeof(buffer))>0));

写部分相同

答案 1 :(得分:1)

OP试图复制整个内容但是有两个不相交的while循环。第一个将所有数据读入同一个小缓冲区。然后缓冲区的最后一些内容用于无休止地写入缓冲区。

只需要1个while循环。写缓冲区需要使用读取的数据长度,而不是sizeof buffer

int fileread = open("/tmp/des.py", O_RDONLY);
int filewrite = open("/tmp/original.txt", O_WRONLY|O_CREAT);
// After successfully opening ...
char buffer[1024];
ssize_t inlen;
ssize_t outlen;
while((inlen = read(fileread, buffer, sizeof buffer)) > 0) {
  outlen = write(filewrite, buffer, inlen);  // Note use of inlen
  if (inlen != outlen) {
    handle_error();
  }
}
if (inlen < 0) {
  handle_error();
}
close(filewrite);
close(fileread);

答案 2 :(得分:0)

你需要

size_t bytesRead = 0;
while((bytesRead=read(fileread,buffer,sizeof(buffer))>0));

你需要这个,因为read返回读取的符号数,所以在你的情况下你只是覆盖了文件句柄。