如何在C或C ++中复制文本文件?
当试图将文本文件A复制到另一个文件B时,可能有几种方法:1)逐字节2)逐字逐句3)逐行
哪一个更有效率?
使用缓冲区:
#include int main() { std::ifstream inFile("In.txt"); std::ofstream outFile("Out.txt"); outFile << inFile.rdbuf(); }
C ++ fstream在内部进行缓冲。 他们使用有效的缓冲区大小(尽管人们对流的效率有所说:-)。 所以只需将一个流缓冲区复制到一个流中,然后在内部魔法将一个流的高效副本复制到另一个流。
但是学习使用std :: copy()通过char进行char更加有趣。
只是“缓冲区缓冲”,以二进制模式复制文件和读/写X字节长部分。 我认为最快的解决方案是使用C语言本身的复制function或系统调用。
最大的缓冲区将为您提供更少的HDD查找数据操作(更快的复制),但更多的RAM使用。
如果做得好,Byte by byte更有效。 当然,这不是整个故事:它取决于您一次复制多少字节。 如果你逐字节地复制字节,你将为每个字节进行一次I / O调用,最终比字符串库慢。 大多数人只是猜测一个好的缓冲区大小(通常为2048或更大,为2的倍数)并使用它。
如果逐行或逐行进行,则很难重建原始文件,因为有多种forms的换行符(\ r,\ n,\ r \ n)和空格(\ p,\ f,0x32)嵌入在文本文件中,您可能会以这种方式松散。
复制文件的最有效方法是使用字节缓冲区。 缓冲区越大,复制效率越高,只要缓冲区大小不大于硬盘内部缓冲区大小(目前大多数为8mb)。
尝试使用C ++ iostream和STL。 以下是一个例子:
ifstream infile("to_copy.txt"); if (infile) { istreambuf_iterator ifit(infile); ofstream outfile("the_copy.txt"); ostreambuf_iterator ofit(outfile); if (outfile) { copy(ifit, istreambuf_iterator (), ofit); outfile.close(); } else { cerr << "Could not open output file" << "\n"; } infile.close(); } else { cerr << "Could not open input file" << "\n"; }
注意 :这可能并不适合所有情况。 根据您的具体要求使用/定制它(例如普通或大量文件)。
我实际上必须自己做同样的事情,所以我用各种尺寸计时。 我发现,给定一个大文件,所花费的时间几乎完全取决于我执行了多少I / O(无论其大小如何)。
因此,最好的办法是尽量减少I / O. 最好是两个(一个读取,另一个写入)。