boost-serialization相关内容
我一直在使用 Boost 序列化库,它实际上非常好,让我可以制作简单的包装器来将我的可序列化对象保存为字符串,如下所示: namespace bar = boost::archive;命名空间 bio = boost::iostreams;模板内联 std::string saveString(const T & o) {std::ostringstream oss;bar::binary_oa
..
下面的代码生成一个 xml 文件,但是,当它循环映射时,它总是将映射键命名为 first,将值命名为 second 有没有办法可以自定义标签名称first和second到groupid和groupType,如图所示在所需的输出 #include #include #include #include #include #include #include 使用命名空间标准;类 MyConne
..
我正在尝试反序列化一个没有默认构造函数的对象.我已经看到您可以通过将存档传递给构造函数来做到这一点.但是,当我这样做时,它似乎没有正确读取数据?这是一个示例 - Works() 输出“1 2",因为它应该(使用默认构造函数和运算符>>),但 DoesntWork() 输出“0 0".我已经通过了,一切似乎都得到了适当的调用.谁能解释一下这两个函数的区别? #include #include #i
..
我正在尝试序列化一个类. 类定义: class StartPeerSessionRequest {上市:StartPeerSessionRequest();虚拟 ~StartPeerSessionRequest();void composeRequestwithHardCodeValues();无效保存();字符串流序列化请求;/*boost::serialization::binary_
..
我正在尝试使用下面的示例序列化和反序列化原始 C 指针及其数据.它似乎序列化得很好,但我不确定如何使其反序列化 - 当我反序列化它时,它只会因内存访问冲突异常而崩溃.我想这是因为它不知道如何反序列化它,但我在哪里指定? 使用向量不是一种选择,在非常大的原始数据量中它非常慢 #include #include #include #include #pragma 警告(推送)
..
我知道有一个Boost模块序列化的boost::shared_ptr,但我找不到任何东西对于 std::shared_ptr. 另外,我不知道如何轻松实现它.恐怕下面的代码 命名空间提升{命名空间序列化{模板内联无效序列化(存档 & ar,std::shared_ptr &t,const unsigned int 版本){if(Archive::is_loading::value)
..
我需要对用 C++ 编写的库进行性能测试.该库由几组结构组成.我已经对这些类进行了序列化测试,但不确定如何对这些类进行性能测试.下面是库中结构的示例 struct X{上市:内部 p;双 q;X();~X();}结构体{浮动米;双 n;Y();~Y();}结构体{上市:std::map>X型;std::map>类型;国际我;字符串
..
我尝试为我的非成员 serialize() 函数提供 A 类的 getter,因为从成员访问是私有的. templateA级{上市:A(const T& id) : m_id(id) {}夯;getRef() { 返回 m_id;}//没有给出好的结果T getId() { 返回 m_id;}//没有给出好的结果const T&getRef() const { 返回 m_id;}//没有给出好的
..
我有一个 pointAccumulator 的抽象基类.这个抽象的基础将用诸如返回所有点的平均值的函数之类的方法来填充.这两个类的示例如下所示: class lala {民众:虚拟 someFunctions = 0;虚拟布尔 isEmpty() = 0;};类 lalaLower : 公共 lala {民众:lalaLower(){}~lalaLower(){}一些函数模板void seria
..
嗨,有人已经设法使用 boost::serialization 序列化 C++11 std::shared_ptr.有很多过时的帖子,但没有一个可以接受的解决方案.我不打算讨论为什么我要使用 std::shared_ptr 接受它! 我发现了另一个帖子:boost serialize 和 std::shared_ptr 但它没有回答我的问题如何序列化 std::shared_ptr 它只建议
..
在C ++中,我遇到了一个问题,即在拥有指向基类的指针的同时调用派生类的函数. 编辑:一些答案使我想到了 CRTP 但是我的意思是我需要有一个指向"Base *"类而不是"Base *"的指针,因为我不知道当前正在处理的类型(当前实例是从某种工厂创建的) 课程: class基础{..templatefunc(T arg){...};};派生类1:公共
..
我有3个班级(“领导者",“研究人员",“工人"),这些班级均来自基本班级“团队". 我有一个“项目"类,其中包含指向不同团队的指针的向量. 我在所有类声明中都以此顺序使用以下所有标头: #include#include#include
..
简而言之,我想知道boost :: serialization在通过指针反序列化时如何为对象分配内存.在下面,您将找到我的问题的一个示例,在伴随的代码中清楚地说明了该示例.该代码应具有完整的功能并可以很好地进行编译,本质上没有错误,仅是有关代码实际工作方式的问题. #include//空值#include#include#inclu
..
我是新来提升&提升序列化.我正在尝试反序列化STL映射类成员.这是代码: ...类脸{朋友std :: ostream&运算符无效序列化(Archive& ar,const unsigned int/
..
boost :: serialization 包含此代码: reinterpret_cast(static_cast(reinterpret_cast(1
..
我正在尝试将成员变量添加到Boost存档类中.在此之后,我想到了:/p> #include#include#includeclass MyOArchive:公共boost :: archive :: text_oarchive_impl
..
当我将派生对象序列化到文件中,并在使用boost导出宏时从该文件序列化到基类指针时,出现unregistered_class异常.当我用存档的register_type()方法替换宏时,它可以工作.我需要使用宏,因为应用程序的大小和复杂性使register_type()方法不切实际. 我正在使用RHEL 7.4,boost 1.53和C ++ 11.这些类在共享库中.这里是示例代码来演示此问
..
我希望从其关联的接口序列化一个多态的类. 这是我找到的这个问题,似乎可以满足我的需要: 通过这种尝试,我得到一个异常 what():未注册的类-未注册或导出的派生类. 我尝试在 NetworkMessageLogin 上使用 CLASS_BOOST_EXPORT ,但是没有成功,我只是遇到了很多错误. 如何从实现我的序列化方法的类的接口实现序列化? 解决方案 您正在
..
你好,我有一个实现libeigen2的代码来计算特征向量。现在,我想使用boost :: serialization保存信息以供以后检索。从示例教程来看, class RandomNode { private: 朋友类boost :: serialization ::访问; template void serialize(Archive& ar,c
..
我正在尝试序列化本征矩阵。这样我就可以序列化一个更复杂的对象。 我使用Matrix作为基类,并将序列化包含在派生类中。我对如何处理Matrix.data()感到困惑,该方法会返回C样式的数组(如果我正确的话)。 这是我的尝试: #include #include
..