5

可以/如何使用谷物库序列化数组。

IE

void save(Archive & ar, const unsigned int version) const
{
    unsigned int l  = g1_size_bin(g,POINT_COMPRESS);
    uint8_t data[l];
    memset(data, 0, l);
    g1_write_bin(data, l, g,POINT_COMPRESS);
    ar(l);
    ar(data); // what should be here
}

那是行不通的(我也不希望这样做)。也没有

ar(cereal::binary_data(data,l)); 

(我认为这会起作用,因为它看起来像人们会使用的 boost 代码),这会产生编译错误:

/usr/local/include/cereal/cereal.hpp:79:17:注意:候选模板被忽略:替换失败:可变修改类型'unsigned char(&)[l]'不能用作模板参数 BinaryData binary_data(T && 数据,size_t 大小)

也没有

ar.saveBinaryValue(data,l);

由于该方法似乎只支持 XML/Json 并且我想要一个二进制存档。

4

1 回答 1

9

cereal::binary_data是在这种情况下使用的正确构造,假设您想要 POD 数组的二进制表示。这仅适用于支持binary_data(二进制和可移植二进制)的档案。 binary_data不适用于基于文本的存档,因为它被视为对更通用的序列化方法的优化 - 请参阅矢量如何序列化以获取此示例。

无论如何,这是一个序列化 C 样式数组的工作示例:

#include <cereal/archives/binary.hpp>
#include <iostream>

int main()
{
  std::stringstream ss;

  {
    cereal::BinaryOutputArchive ar(ss);
    std::uint8_t data[] = {1, 2, 3};
    ar( cereal::binary_data( data, sizeof(std::uint8_t) * 3 ) );
  }

  {
    cereal::BinaryInputArchive ar(ss);
    std::uint8_t data[3];
    ar( cereal::binary_data( data, sizeof(std::uint8_t) * 3 ) );

    for( int i : data )
      std::cout << i << " ";
  }

  return 0;
}

如果您想将 C 样式数组序列化为基于文本的存档,或者如果您的数组不是 POD 类型,则需要遍历每个对象并单独序列化它。

于 2015-01-02T22:24:10.457 回答