【ProtoBuf 语法详解】选项 option

文章目录

  • [1. 选项 option](#1. 选项 option)
  • [2. 选项分类](#2. 选项分类)
  • [3. 常用选项列举](#3. 常用选项列举)
  • [4. 设置自定义选项](#4. 设置自定义选项)

1. 选项 option

.proto 文件中可以声明许多选项,使用 option 标注。选项能影响 proto 编译器的某些处理方式。

2. 选项分类

选项的完整列表在 google/protobuf/descriptor.proto 中定义。

选项分为 文件级消息级字段级 等等,但并没有一种选项能作用于所有的类型。

3. 常用选项列举

optimize_for :该选项为文件选项,可以设置 protoc 编译器的优化级别,分别为 SPEEDCODE_SIZELITE_RUNTIME。受该选项影响,设置不同的优化级别,编译 .proto 文件后生成的代码内容不同。

  • SPEED:protoc 编译器将生成的代码是高度优化的,代码运行效率高,但是由此生成的代码编译后会占用更多的空间。SPEED 是默认选项。
  • CODE_SIZE:proto 编译器将生成最少的类,会占用更少的空间,是依赖基于反射的代码来实现序列化、反序列化和各种其他操作。但和 SPEED 恰恰相反,它的代码运行效率较低。这种方式适合用在包含大量的 .proto 文件,但并不盲目追求速度的应用中。
  • LITE_RUNTIME:生成的代码执行效率高,同时生成代码编译后的所占用的空间也是非常少。这是以牺牲 Protocol Buffer 提供的反射功能为代价的,仅仅提供 encoding+序列化功能,所以我们在链接 BP 库时仅需链接 libprotobuf-lite,而非 libprotobuf。这种模式通常用于资源有限的平台,例如移动手机平台中。

示例代码如下:

proto 复制代码
option optimize_for = LITE_RUNTIME;

allow_alias:允许将相同的常量值分配给不同的枚举常量,用来定义别名。该选项为枚举选项。

举个例子:

proto 复制代码
enum PhoneType {
    option allow_alias = true;
    MP = 0;
    TEL = 1;
    LANDLINE = 1;  // 若不加 option allow_alias = true; 这一行会编译报错
}

4. 设置自定义选项

ProtoBuf 允许自定义选项并使用。该功能大部分场景用不到,在这里不拓展讲解。

有兴趣可以参考:Language Guide (proto 2)

相关推荐
handler0116 分钟前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
知识的宝藏28 分钟前
Xpaht self::div 轴语法
开发语言
keykey6.29 分钟前
卷积神经网络(CNN):让AI学会“看“
开发语言·人工智能·深度学习·机器学习
IsJunJianXin32 分钟前
谷歌搜索cookie NID逆向生成
开发语言·python·google搜索·sgss·nid-cookie·算法生成nid·google-cookie
weikecms41 分钟前
美团霸王餐报名API接口
java·开发语言
繁星蓝雨1 小时前
C++中对比pragma once和ifndef的使用区别
开发语言·c++·ifndef·头文件·pragma once
.千余1 小时前
【C++】C++手写Vector容器:从底层源码模拟实现
开发语言·c++·经验分享·笔记·学习
a诠释淡然1 小时前
C++ vs Rust:哪个更适合你的下一个项目?
开发语言·c++·rust
meilindehuzi_a1 小时前
深入理解 JavaScript 执行机制:从编译阶段到调用栈底层实现
开发语言·javascript·ecmascript
小小de风呀1 小时前
de风——【从零开始学C++】(十二):stack和queue的基本使用和模拟实现
开发语言·c++