码迷,mamicode.com
首页 > 其他好文 > 详细

文件复制二进制版

时间:2016-03-08 00:17:14      阅读:217      评论:0      收藏:0      [点我收藏+]

标签:

两种复制方式:

FILE *src = fopen("src.txt","r");

FILE *dest = fopen("dest.txt","w");

Char buf[1024]={0};

While(!feof(src)){

Size_t size = fread(buf,1,sizeof(buf),src);

Fwrite(buf,1,size,dest);

}

 

采用 stat函数

#include <sys/stat.h>

Struct stat st;

stat("src.txt",&st);

char buf[] = malloc(st.st_size);

fread(buf,st.st_size,1,src);

fwrite(buf,st.st_size,1,dest);

//记得释放内存

Free(buf);

 

 

 

这两种写法都是可以的,第二种是通过空间换时间。因为他就执行一次,所以速度很快效率很高。但是文件不能很大,所以可以做一个判断,如果文件在多大范围之内,就采用这个方式来复制,利用空间换取时间。

第一种写法是一种通吃的写法,都可以完成复制,只是速度上会比第二个慢。好处是多大都能完成复制。

但是我们一般这个缓冲区也有说法,不做的太大,也不做的太小。

太大可能造成缓冲区的浪费,太小的话移动次数会过多。

所以经过比较长久的这样一种尝试和考量决定把这个数字设定在64*1024.也就是64k。一般内存页就是64k的大小了。

 

 

下面给出一个文件复制的简单版本。当然还没有试过多大之内可以使用stat函数,并且也没有做出递归。

先来尝试文件大小的部分。

 

main.c

#include <stdio.h>
#include <sys/stat.h>
#pragma warning(disable:4996)

#define MAXSIZE4FUNC2 1038684887//一个已经检测过的大小为990Mb的zip文件。这个数是10亿个字节,所以感觉1G以内的文件都可以的。
#define _1G 1073741824//这是计算得到的1G=1073741824个字节。
#include "func1.h"
#include "func2.h"

/** 

    可以做成双击执行版本的。
    单个文件,还要迭代?
    判断当前是文件还是目录

*/
void workflow(const int,const char **);
void judgeEntrance(const char **argv, const FILE *src, FILE *dest);
int main(int argc,char **argv){
    
    workflow(argc,argv);

    //FILE *src = fopen("a.txt", "r");
    //FILE *dest = fopen("2b.txt", "w");
    //copy1(src, dest);
    //copy2("a.txt", src, dest);
    //fclose(src);
    //fclose(dest);

    return 0;
}

void workflow(const int argc, const char **argv){
    if (argc < 3){
        printf("参数过少,需要三个参数");
    }
    else if (argc>3){
        printf("参数过多,需要三个参数");
    }
    else{
    
        FILE *src = fopen(argv[1], "rb");
        FILE *dest = fopen(argv[2], "wb");
        judgeEntrance(argv,src,dest);
        fclose(src);
        fclose(dest);
    }
}
void judgeEntrance(const char **argv,const FILE *src,FILE *dest){

    struct stat st;
    stat(argv[1], &st); 
    if (st.st_size < _1G){//空间换时间的做法
        copy2(argv[1], src, dest);
    }
    else{//通配的做法
        copy1(src, dest);
    }
    printf("%d", st.st_size);
}

 

func1.h

#ifndef _FUNC1_H
#define _FUNC1_H
#include <stdio.h>

void copy1(FILE *src, FILE *dest);

#endif 

func1.c

#include <stdio.h>

void copy1(FILE *src, FILE *dest){
    char buf[1024 * 64] = { 0 };
    while (!feof(src)){
        size_t size = fread(buf, 1, sizeof(buf), src);
        fwrite(buf, 1, size, dest);
    }
}

func2.h

#ifndef _FUNC2_H
#define _FUNC2_H
#include <stdio.h>

void copy2(const char *srcstrname, const FILE *src, FILE *dest);

#endif

func2.c

#include <sys/stat.h>
#include <stdio.h>

void copy2(const char *srcstrname, const FILE *src, FILE *dest){
    struct stat st;
    stat(srcstrname, &st);
    char *buf = malloc(st.st_size);
    fread(buf, st.st_size, 1, src);
    fwrite(buf, st.st_size, 1, dest);
    free(buf);
}

 

 

 

 

文件复制二进制版

标签:

原文地址:http://www.cnblogs.com/letben/p/5252180.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!