文件拷貝代碼以及疑問

Linux下的拷貝代碼,沒有用ANSI庫函數
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <string.h>
#define BUFFER_SIZE 1024
 
int main(int argc,char **argv){
 
    int from_fd,to_fd;
    int bytes_read,bytes_write;
    char buffer[BUFFER_SIZE];
    char *ptr;
     
    if(argc!=3)    {
        fprintf(stderr,"Usage:%s fromfile tofile\n\a",argv[0]);
        exit(1);
    }
     
    /* 打開源文件 */
    if((from_fd=open(argv[1],O_RDONLY))==-1)
    {
    fprintf(stderr,"Open %s Error:%s\n",argv[1],strerror(errno));
    exit(1);
    }
    /* 創建目的文件 */
    if((to_fd=open(argv[2],O_WRONLY|O_CREAT,S_IRUSR|S_IWUSR))==-1)
    {
    fprintf(stderr,"Open %s Error:%s\n",argv[2],strerror(errno));
    exit(1);
    }
     
    /* 以下代碼是一個經典的拷貝文件的代碼 */
        while(bytes_read=read(from_fd,buffer,BUFFER_SIZE)){
        /* 一個致命的錯誤發生了 */
        /*除了被其它信號中斷之外,其它所有的錯誤都是由程序自身引起的,顯然需要退出*/
        if((bytes_read==-1)&&(errno!=EINTR)) break;
        else if(bytes_read>0)
        {
            ptr=buffer;
            while(bytes_write=write(to_fd,ptr,bytes_read)){
                /* 一個致命錯誤發生了 */
                if((bytes_write==-1)&&(errno!=EINTR))break;
                /* 寫完了所有讀的字節 */
                else if(bytes_write==bytes_read) break;
                /* 只寫了一部分,繼續寫 */
                /*簡單測試之後發現,如下的情況並未出現,難道是考慮中斷後處理的?*/
                else if(bytes_write>0)
                {
                ptr+=bytes_write;
                bytes_read-=bytes_write;
                }
            }
        if(bytes_write==-1)break;
        }
            }
    close(from_fd);
    close(to_fd);
    exit(0);
}
接下來是Windows下的代碼,使用ANSI庫函數
#include <stdio.h>
#include <errno.h>

#define BUF_SIZE    256

int main(int argc, char *argv[])
{
    FILE *in_file, *out_file;
    char data[BUF_SIZE];
    size_t bytes_in, bytes_out;
    long len = 0;

    if ( argc != 3 )
    {
        printf("Usage: %s file1 file2\n", argv[0]);
        return 1;
    }

    if ( (in_file = fopen(argv[1], "rb")) == NULL )
    {
        perror(argv[1]);
        return 2;
    }
    if ( (out_file = fopen(argv[2], "wb")) == NULL )
    {
        perror(argv[2]);
        return 3;
    }


    while ( (bytes_in = fread(data, 1, BUF_SIZE, in_file)) > 0 )
    {
        bytes_out = fwrite(data, 1, bytes_in, out_file);
        if ( bytes_in != bytes_out )
        {
            perror("Fatal write error.\n");
            return 4;
        }
        len += bytes_out;
        printf("copying file .... %d bytes copy\n", len);
    }

    fclose(in_file);
    fclose(out_file);

    return 0;
}
我自己寫的代碼,本意是使用ANSI庫函數,編譯出來的程序在Windows和Linux下都可以運行,但並沒有成功,出現了一些詭異的問題,mark之,以後解決。
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>

#define BUFFER_SIZE 6

int main(int argc, char *argv[])
{
    FILE *from_file, *to_file;
    char buffer[BUFFER_SIZE];
    int bytes_read, bytes_write;
    char *ptr;

    if(argc!=3) {
        fprintf(stderr, "Useage: %s fromefile tofile\n\a",argv[0]);
        exit(1);
    }

    if((from_file=fopen(argv[1], "rb")) == NULL) {
        fprintf(stderr, "Can't open %s.Error: ", argv[1]);
		perror(argv[1]);
        exit(1);
    }

    if((to_file=fopen(argv[2], "wb")) == NULL) {
        fprintf(stderr, "Can't open %s.Error:", argv[2]);
		perror(argv[2]);
        exit(1);
    }
    
    while (bytes_read=fread(buffer, sizeof(char), BUFFER_SIZE, from_file)) {
        if(bytes_read==-1)  break; //&& (error!=EINTR))
        else if(bytes_read>0)
        {
            ptr=buffer;
            while(bytes_write=fwrite(buffer, sizeof(char), BUFFER_SIZE, to_file)) {
                if(bytes_write==-1) break; // && (error!=EINTR))
                else if(bytes_write==bytes_read) break;
                else if(bytes_write>0)
                {
                    ptr+=bytes_write;
                    bytes_read-=bytes_write;
                }
            }
            if(bytes_write==-1) break;
        }
    }
    fclose(from_file);
    fclose(to_file);
    exit(0);
}

問題:

1.error!=EINTR代表什麼含義,這條語句在Windows下編譯不過去。

EINTR表示在Linux下被信號量意外打斷

2.else if(bytes_write>0),什麼情況下能進入這個判斷語句?

3.最詭異的就是當BUFFER_SIZE設置爲大於6的數字,就無限循環,導致產生的文件不斷增大,百思不得其解。

參考:

http://bbs.chinaunix.net/thread-1003488-1-1.html

http://bbs.csdn.net/topics/350254194

發佈了33 篇原創文章 · 獲贊 4 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章