我需要将地图的内容(键是int的ID,值是自定义的struct)写入文件中,稍后从文件中加载它。我可以在带有CArchive的MFC中进行吗?
谢谢!
答案 0 :(得分:7)
在MFC中,我认为最简单的方法是首先序列化地图的大小,然后简单地遍历所有元素。
您没有指定使用std::map
还是MFC CMap
,但基于std::map
的版本可能如下所示:
void MyClass::Serialize(CArchive& archive)
{
CObject::Serialize(archive);
if (archive.IsStoring()) {
archive << m_map.size(); // save element count
std::map<int, MapData>::const_iterator iter = m_map.begin(),
iterEnd = m_map.end();
for (; iter != iterEnd; iter++) {
archive << iter->first << iter->second;
}
}
else {
m_map.clear();
size_t mapSize = 0;
archive >> mapSize; // read element count
for (size_t i = 0; i < mapSize; ++i) {
int key;
MapData value;
archive >> key;
archive >> value;
m_map[key] = value;
}
}
}
如果在读取存档时发生错误,其中一个流操作应抛出异常,然后由更高级别的框架捕获。
答案 1 :(得分:1)
我对MFC知之甚少,但使用Boost.Serialization
可以轻而易举地解决您的问题struct MapData {
int m_int;
std::string m_str;
private:
friend class boost::serialization::access;
template<class Archive>
void serialize(Archive &ar, const unsigned int version)
{
ar & m_int;
ar & m_str;
}
};
std::map< int, MapData > theData;
template<class Archive>
void serialize(Archive & ar, std::map< int, MapData > & data, const unsigned int version)
{
ar & data;
}
然后你想要真正存档:
std::ofstream ofs("filename");
boost::archive::binary_oarchive oa(ofs);
oa << theData;
就是这样。
(免责声明:代码只需在此框中输入,根本不进行测试,打算使用拼写错误;)