我想通过读取数据块来复制文件,发送它,然后再把它放回一起。发送不是问题的一部分,所以我在代码中省略了它。它应该可以处理任何类型的文件和任意的piece_length。
这只是一个前期阶段。最后,数据块不应该按顺序选择,而是随机选择。在接收到另一个数据块之间可能会有一段时间。
我知道这个例子是有意义的,如果size % piece_length != 0
。
我在另一端得到与原始文件相同大小的崩溃文件。有人发现问题了吗?
int main ()
{
string file = "path/test.txt"
string file2 = "path2/test.txt";
std::ifstream infile (file.c_str() ,std::ifstream::binary);
//get size of file
infile.seekg (0,infile.end);
long size = infile.tellg();
infile.seekg (0);
size_t piece_length = 5;
for (int i = 0; i < ((size / piece_length) + 1); i++)
{
if ( i != (size / piece_length))
{
std::ifstream infile (file.c_str() ,std::ifstream::binary);
infile.seekg((i * piece_length) , infile.beg);
char* buffer = new char[piece_length];
infile.read(buffer, piece_length);
infile.close();
std::ofstream outfile (file2.c_str() ,std::ofstream::binary);
outfile.seekp((i * piece_length), outfile.beg);
outfile.write(buffer, piece_length);
outfile.close();
}
else
{
std::ifstream infile (file.c_str() ,std::ifstream::binary);
infile.seekg((i * piece_length) , infile.beg);
char* buffer = new char[size % piece_length];
infile.read(buffer, size % piece_length);
infile.close();
std::ofstream outfile (file2.c_str() ,std::ofstream::binary);
outfile.seekp((i * piece_length), outfile.beg);
outfile.write(buffer, size % piece_length);
outfile.close();
}
}
return 0;
}
要回答您的具体问题,您需要打开outfile
, ios::in | ios::out
在标志中,否则它默认为只写模式并破坏文件中已经存在的内容。写到现有二进制文件的中间c++
你可以考虑以下几点:
- 如果您只是将部分写入文件的末尾,只需使用
ios::app
(追加)。甚至不需要查找。 - 你不需要一直重新打开
infile
甚至outfile
,只需重复使用它们。 - 您也可以重用
buffer
。请记住delete
,或者最好使用std::vector
。