Protobuf 小记

公司内部出现protobuf接口库太大的问题,

protobuf option 部分选项:

option optimize_for = LITE_RUNTIME;

      optimize_for是文件级别的选项,Protocol Buffer定义三种优化级别SPEED/CODE_SIZE/LITE_RUNTIME。缺省情况下是SPEED。

      SPEED: 表示生成的代码运行效率高,但是由此生成的代码编译后会占用更多的空间。

      CODE_SIZE: 和SPEED恰恰相反,代码运行效率较低,但是由此生成的代码编译后会占用更少的空间,通常用于资源有限的平台,如Mobile。

      LITE_RUNTIME: 生成的代码执行效率高,同时生成代码编译后的所占用的空间也是非常少。这是以牺牲Protocol Buffer提供的反射功能为代价的。因此我们在C++中链接Protocol Buffer库时仅需链接libprotobuf-lite,而非libprotobuf。在Java中仅需包含protobuf-java-2.4.1-lite.jar,而非protobuf-java-2.4.1.jar。

      注:对于LITE_MESSAGE选项而言,其生成的代码均将继承自MessageLite,而非Message。   


protobuf C++ 可选参数arena allocation show 10-20% speedup.

你可能感兴趣的:(Protobuf 小记)