这取决于您如何定义 proto 文件中的重复字段。根据nanopb docs,您要么repeated
像以前那样指定字段,然后在编码/解码期间使用回调函数分别处理每个项目,要么使用特定于 nanopb 的设置,因此具有固定长度的数组:
- 默认情况下,任何类型的字符串、字节和重复字段都映射到回调函数。
- 如果文件
(nanopb).max_size
中指定了特殊选项.proto
,则字符串映射到以空字符结尾的字符数组,字节映射到包含字符数组和大小字段的结构。
- 如果
(nanopb).fixed_length
设置为true
并且(nanopb).max_size
也设置了,则字节映射到固定大小的内联字节数组。
- 如果
(nanopb).max_count
在重复字段上指定了特殊选项,则它将映射到正在重复的任何类型的数组。将为实际存储的条目数创建另一个字段。
例如,字节数组需要使用max_size
:
required bytes data = 1 [(nanopb).max_size = 40, (nanopb).fixed_length = true];
当使用 nanopb 编译时,这将创建以下字段:
// byte arrays get a special treatment in nanopb
pb_byte_t data[40];
或者,对于 a float
,您将max_count
根据规则 4 使用:
repeated float data = 1 [(nanopb).max_count = 40];
然后你会得到:
size_t data_count;
float data[40];
如果您repeated
像之前一样简单地定义一个字段,那么 nanopb 将创建一个回调函数:
// repeated float value = 1;
pb_callback_t value;
这意味着您必须提供自己的函数来处理每个传入的项目:
yourobject.value.arg = &custom_args;
yourobject.value.funcs.decode = custom_function_for_decoding;