为什么make_nvp需要非常量参考?
Why make_nvp needs non-const reference?
为什么在这里引用非常量?
template<class T>
const nvp< T > make_nvp(const char * name, T & t);
我问的原因是我有一个带有公共字段的结构,我需要将它们设为私有并使用访问器。所以我想知道是否允许我使用临时变量并将它们传递给make_nvp
或者我需要与数据结构的序列化程序交朋友。
// option 1
auto a = data.getA();
ar & make_nvp("A", a);
// option 2
ar & make_nvp("A", data._a); // _a is private, but serializer is friend
我不知道这是什么ar
因为它是一个模板化参数,所以在某些情况下它可以利用这种非恒定性并将其保存以供以后使用,然后option 1
是有问题的。
在 boost 存档中,您可以使用单个函数进行序列化和反序列化。这是通过使用 archive 作为模板参数来实现的 - 它可以是序列化结构的输出存档,也可以是从某个文件加载结构的输入存档。对于反序列化,函数需要一个非常量引用来存储反序列化的值,这就是make_nvp
需要一个非常量引用的原因。
回到你的问题:选项 2 更有意义,因为选项 1 破坏了反序列化。
选项 1 会中断对象跟踪,只要您不序列化任何指向data._a
或其内部的指针
相关文章:
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 什么时候在C++中返回常量引用是个好主意
- 代理对象的常量正确性
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 通过多个头文件使用常量变量
- 在cuda线程之间共享大量常量数据
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 是默认情况下分配给char数组常量的值
- 私有类型的静态常量成员
- OpenGL大的3D纹理(>2GB)非常慢
- 类似枚举的计算常量
- 递归模板化函数不能分配给具有常量限定类型"const tt &"的变量"state"
- 使用常量键但非常量值进行映射
- 为什么`is_open()`非常常量
- 从getter方法返回常量和非常量值
- 阻止const类函数在引用成员上调用非常常量类函数
- C++初始化非常大的常量数组,最佳实践
- 提高c++中非常大的常量的可读性