关闭

【转】c++文件复制

标签: c++iteratoroutputiosinputalgorithm
7621人阅读 评论(2) 收藏 举报
分类:

转帖,转帖位置忘了

使用C++标准程序库的输入输出流(I/O Stream)复制文件,存在许多的方法,

方法一:逐个字符复制

#include < fstream >

std::ifstream input("in",ios::binary);
std::ofstream output("out",ios::binary);
char ch;

while (input.get(ch)) output << ch;

注意:如果使用input>>ch读取字符,则必须先调用input.unsetf(ios::skipws)取消输入流默认的跳过空白符的输入格式,因为换行符是空白符的一种。(BEN注:流失操作以空白字符'/0'为字符串的分割,并忽略它们,直接操作会缺失这些空白字符)

方法二:逐行复制

#include < fstream >
#include < string >

std::ifstream input("in",ios::binary);
std::ofstream output("out",ios::binary);
std::string line;

while (getline(input,line)) output << line << "/n";

注意:这里的代码有一个小小的缺陷,如果文件不是纯文本格式的文件,或者文本文件的最后没有换行符,那么会导致复制后的文件末尾添加了一个多余的换行符。(BEN注:可以使用.gcount ()来判断是否到达文件尾,到达则不添加多余的'/n')

方法三:迭代器复制

#include < fstream >
#include < iterator >
#include < algorithm >

std::ifstream input("in",ios::binary);
std::ofstream output("out",ios::binary);
input.unsetf(ios::skipws);

copy(istream_iterator(input),istream_iterator(),ostream_iterator(output,""));

同样这里也有一个小技巧,输入流的格式默认为跳过空白字符,因此调用unsetf取消这个格式,才可保证正确的复制。

方法四:缓冲区复制

#include < fstream >

std::ifstream input("in",ios::binary);
std::ofstream output("out",ios::binary);

output << input.rdbuf();

这里直接使用了输入流的缓冲区,因此没有引入额外的临时对象。(BEN注:不管哪种方式操作,最好都使用缓冲提高效率,比如,可以使用字符串存储文件内容,再一次性写入到新文件,这样可以减少对文件的操作,因为对文件存储器的操作也就是I/O设备相对于内存是极其缓慢的)

很显然,上述四种方法中,最后一种方法最简洁,由于直接操作输入流的缓冲区,从运行效率上来说,也比其他方法有着略微的优势(当然,由于操作系统可能提供了额外的基于设备的文件缓冲机制,也许你无法证实这一点)。因此,除非要对输入内容进行处理,直接复制文件推荐最后一种方法,既不容易出错,又能获得良好的性能。

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:164664次
    • 积分:2083
    • 等级:
    • 排名:第18386名
    • 原创:32篇
    • 转载:38篇
    • 译文:1篇
    • 评论:15条
    文章分类
    最新评论