1.发现存在内存泄露。
程序退出时记得调用:
google::protobuf::ShutdownProtobufLibrary();
这里一定是在程序退出时调用,如果调用后又使用了 protobuf 会出现异常,因为protobuf 中使用构造 会有创建指针,会存入 ShutdownData;
看ShutdownProtobufLibrary 源码:
void ShutdownProtobufLibrary() {
  // This function should be called only once, but accepts multiple calls.
  static bool is_shutdown = false;
  if (!is_shutdown) {
    delete internal::ShutdownData::get();
    is_shutdown = true;
  }
}解决方案:
定义成全局,全局只释放一次
struct A {
     ~A(){
          google::protobuf::ShutdownProtobufLibrary() ;
     }
 };
 A  _globalProtobuf;2.内存有异常:
可能是:protobuf 中的嵌套消息的使用临时变量例:
string sn="1111";
string Algo="3333";
request.set_sn(sn);
request.set_algo(Algo);
如果在其它地方使用可能会有异常;需要去new,退去时记得 release_eventcode
PointProtos::Event *event = mUploadLogInfoData->add_events();
string* ans = event->mutable_eventcode();
(*ans)=key;
string* tvalue = event->mutable_eventcode();//
(*tvalue)= value ;
  如果是对象一样:
 
for(int index = 0;index<info.answer_size();index++)
{
Detail * detail = rsp.add_detail();
Answer* ans = detail->mutable_answer();
Answer temp_ans = info.answer(index);
ans->copyFrom(temp_ans);
}
  
总结:protobuf 中的嵌套消息的使用主要对set_allocated_和mutable_的使用
1 使用set_allocated_,赋值的对象需要new出来,不能用局部的,这里保存的是对象的指针。
2 使用mutable_,赋值时候,可以使用局部变量,因为在调用的时,内部做了new操作。
  










