我想创建一个(json)文件manuyll(使用python)并将其加载到我的c ++应用程序中。
使用ceral保存和加载工作正常。但是,json文件中的polymorphic_ids对我来说并不清楚。
这是一个更清晰的例子: 这是由谷物框架产生的物体: ```
{
"array1": [
{
"key": 0,
"value": {
"ptr_wrapper": {
"id": 2147483649, //!-- ID1
"data": {
...some float fields...
}
}
}
},
{
"key": 1,
"value": {
"ptr_wrapper": {
"id": 2147483650, //!-- This is previous ID+1 and so on...
"data": {
... some float fields...
}
}
}
}
],
"array2": [
{
"key": 0,
"value": {
"polymorphic_id": 2147483649, //!-- this is the very first ID from array 1.
"polymorphic_name": "my_struct_name",
"ptr_wrapper": {
"id": 2147483651, //this ID1+N Elements from array1
"data": {
... also some float stuff...
}
}
}
}
]
}
```
当我观察数字生成时,第一个ID会增加。第二个数组使用第一个ID作为其多态ID,并进一步增加数字。
为什么这些数字被使用有一些逻辑? 是不是一直使用它们,或者当我在另一台机器上运行我的c ++导入器时这些会改变吗?
答案 0 :(得分:2)
ptr_wrappers中的id由grain生成,用于跟踪保存或加载时已经序列化的指针。它们是32位无符号整数,从1开始,并为每个保存的新指针递增。
如果是第一次遇到指针,则最高位设置为1,这样谷物可以避免多次保存数据。如果数据已经保存,谷物将查找先前生成的数字并使用它。请注意,此查找号码不会将MSB设置为1。
有关详细信息,请参阅InputArchive和OutputArchive中的函数registerSharedPointer。
使用自己的计数器以相同的方式生成多态id,请参阅同一文件中的registerPolymorphicType函数。
一般情况下,我不建议尝试手动生成处理多态或共享指针等内容的谷物JSON,因为错误生成这些数字可能会导致程序崩溃。但是,如果你可以确保它们与谷物一样完全生成,它应该可以工作。