为什么 make_nvp 需要非常量引用?
Why make_nvp needs non-const reference?
这里为什么有非常量引用?
template<class T>
const nvp< T > make_nvp(const char * name, T & t);
我问的原因是我有一个包含 public 字段的结构,我需要将它们设为私有并改用访问器。所以我想知道我是否被允许使用临时变量并将它们传递给 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
是有问题的。
选项 1 会破坏对象跟踪,只要您不序列化任何指向 data._a
或其内部的指针就可以。
在 boost 存档中,您可以使用单个函数进行序列化和反序列化。这是通过使用存档作为模板参数来实现的——它可以是序列化结构的输出存档,也可以是从某个文件加载结构的输入存档。对于反序列化,该函数需要一个非常量引用来存储反序列化的值,这就是为什么 make_nvp
需要一个非常量引用。
回到你的问题:选项 2 更有意义,因为选项 1 破坏了反序列化。
这里为什么有非常量引用?
template<class T>
const nvp< T > make_nvp(const char * name, T & t);
我问的原因是我有一个包含 public 字段的结构,我需要将它们设为私有并改用访问器。所以我想知道我是否被允许使用临时变量并将它们传递给 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
是有问题的。
选项 1 会破坏对象跟踪,只要您不序列化任何指向 data._a
或其内部的指针就可以。
在 boost 存档中,您可以使用单个函数进行序列化和反序列化。这是通过使用存档作为模板参数来实现的——它可以是序列化结构的输出存档,也可以是从某个文件加载结构的输入存档。对于反序列化,该函数需要一个非常量引用来存储反序列化的值,这就是为什么 make_nvp
需要一个非常量引用。
回到你的问题:选项 2 更有意义,因为选项 1 破坏了反序列化。