C++ c++;从ifstream中读取一个块,并将其写入ifstream
我想从一个C++ c++;从ifstream中读取一个块,并将其写入ifstream,c++,c++11,C++,C++11,我想从一个ifstream中读取一个字节块,然后写入流的另一个 这是我的密码: size_t chunk_size = ...; std::ifstream ifs(in_file_name); std::ofstream ofs(out_file_name); char * buffer = new char[chunk_size]; ifs.read(buffer, chunk_size); ofs << buffer; delete[] buffer; size\u t c
ifstream
中读取一个字节块,然后写入流的另一个
这是我的密码:
size_t chunk_size = ...;
std::ifstream ifs(in_file_name);
std::ofstream ofs(out_file_name);
char * buffer = new char[chunk_size];
ifs.read(buffer, chunk_size);
ofs << buffer;
delete[] buffer;
size\u t chunk\u size=。。。;
std::ifstream ifs(在文件名中);
std::ofs流(输出文件名);
char*buffer=新字符[块大小];
读取(缓冲区、块大小);
ofs
这样做对吗
不完全是这样。如果您使用,那么您很可能应该将其与
最好使用std::vector
进行内存管理(或至少使用智能指针):
size\u t chunk\u size=。。。;
std::ifstream ifs(在文件名中);
std::ofs流(输出文件名);
{//您可以使用块来限制向量的生存期
std::向量缓冲区(块大小);
读取(buffer.data(),buffer.size());
写入(buffer.data(),buffer.size());
}
代码std::ostream::operator有问题为什么不直接使用write
,来写入缓冲区?char[]
不是streambuffer*
您可以查看streambuf
的文档,看看它是否与char*
远程相关。强烈建议(A)测试read
调用以确保流仍然有效,以及(b)用于确定之后实际有效的缓冲区
,并在执行写入
操作之前执行这两项操作。
size_t chunk_size = ...;
std::ifstream ifs(in_file_name);
std::ofstream ofs(out_file_name);
{ // you can use block to limit lifetime of the vector
std::vector<char> buffer( chunk_size );
ifs.read( buffer.data(), buffer.size() );
ofs.write( buffer.data(), buffer.size() );
}