正确地将std::矢量读取和写入文件

Reading and writing a std::vector into a file correctly

本文关键字:文件 读取 std 正确地      更新时间:2023-10-16

这就是重点。如何编写和读取包含std::vector的二进制文件?

我在想:

//============ WRITING A VECTOR INTO A FILE ================
const int DIM = 6;
int array[DIM] = {1,2,3,4,5,6};
std::vector<int> myVector(array, array + DIM);
ofstream FILE(Path, ios::out | ofstream::binary);
FILE.write(reinterpret_cast<const char *>(&myVector), sizeof(vector) * 6);
//===========================================================

但我不知道如何解读这个向量。因为我认为以下是正确的,但事实并非如此:

ifstream FILE(Path, ios::in | ifstream::binary);
FILE.read(reinterpret_cast<const char *>(&myVector), sizeof(vector) * 6);

那么,如何进行操作呢?

尝试使用ostream_iterator/ostreambuf_iteratoristream_iterator/istreambuf_iterator和STL copy方法:

#include <algorithm>
#include <iostream>
#include <iterator>
#include <vector>
#include <fstream> // looks like we need this too (edit by π)
std::string path("/some/path/here");
const int DIM = 6;
int array[DIM] = {1,2,3,4,5,6};
std::vector<int> myVector(array, array + DIM);
std::vector<int> newVector;
std::ofstream FILE(path, std::ios::out | std::ofstream::binary);
std::copy(myVector.begin(), myVector.end(), std::ostreambuf_iterator<char>(FILE));
std::ifstream INFILE(path, std::ios::in | std::ifstream::binary);
std::istreambuf_iterator iter(INFILE);
std::copy(iter.begin(), iter.end(), std::back_inserter(newVector));

使用boost::serialization

如果您不想使用boost-写入大小和vector

size_t sz = myVector.size();
FILE.write(reinterpret_cast<const char*>(&sz), sizeof(sz));
FILE.write(reinterpret_cast<const char*>(&myVector[0]), sz * sizeof(myVector[0]));

您可以使用

#include <boost/serialization/vector.hpp>

以序列化您的矢量。在此处阅读教程:http://www.boost.org/libs/serialization/doc/tutorial.html#stl`

在读取vector之前,您应该调整其大小:yourVector.size(numberOfElementsYouRead)

此外,sizeof(vector<your_type>)只是vector对象内部实现的大小;矢量元素大小为CCD_ 13。

然后这样读:

file.read(reinterpret_cast<char *>(&myVector[0]), sizeof(vector<int>::element_type) * element_count); 

我使用了这样一个事实,即data()方法返回一个可以用于读取和写入的地址。

//假设outf是一个可写的文件指针(二进制)。//将myVector.size()写入文件,然后写入

fwrite(myVector.data(), sizeof(decltype(myVector)::value_type), myVector.size(), outf);

阅读:

//从文件中读取MyVector.size()作为nv,inpf是读取文件指针

MyVector.resize(nv);
fread(MyVector.data(), sizeof(decltype(MyVector)::value_type), nv, inpf);

坚持io文件中的旧方法,但请忽略这一点(即使这可能会激怒你:))。

缺点是以这种方式不支持endianness。