Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/136.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/url/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 如何使用C+上protobuf中的反射将预分配的消息设置为字段+;?_C++_Protocol Buffers - Fatal编程技术网

C++ 如何使用C+上protobuf中的反射将预分配的消息设置为字段+;?

C++ 如何使用C+上protobuf中的反射将预分配的消息设置为字段+;?,c++,protocol-buffers,C++,Protocol Buffers,我有这样一个代码: TestMessage* output; ::google::protobuf::Message* input; // ... auto extension_field = input->GetDescriptor()->extension(i); // ... auto reflection = output->GetReflection(); reflection->MutableMessage(output, extension_field)-&

我有这样一个代码:

TestMessage* output;
::google::protobuf::Message* input;
// ...
auto extension_field = input->GetDescriptor()->extension(i);
// ...
auto reflection = output->GetReflection();
reflection->MutableMessage(output, extension_field)->CopyFrom(*input);
此代码获取两条消息,检查其中一条消息是否是另一条消息的扩展,将输入消息复制到输出消息的相应扩展字段


我想优化它——用“移动”取代复制。如何使用
reflection

最接近的方法是使用
reflection::Swap
代替
CopyFrom
。顶级对象不会被使用,但其所有子对象(字符串、子消息等)都将被使用


您关于输出字段的建议是正确的。您可以删除答案的第二部分-我将更新问题。好的,删除该部分。此外,您的答案中存在细微的不一致-我无法执行
反射->交换(反射->可变消息(…),输入)
,因为Swap()的第一个参数不是提供
反射的相同消息。Protobuf在运行时抱怨它,所以它应该是另一个反射。
auto msg = reflection->MutableMessage(output, output_field);
msg->GetReflection()->Swap(msg, input);
delete input;