成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

為什么 Go Protobuf 不支持標簽注入?

開發 前端
雖然現在 gogo 這一個開源項目已經進入廢棄階段,但根據 issues 內推薦的情況。可以選擇繼續使用 gogo,或者使用 protoc-go-inject-tag[3] 這一個項目。

大家好,我是煎魚。

前幾天我們交流了 gogo/protobuf 前兩年開始 Deprecated,作者最終放棄更新的事情,還是挺讓人深思的。

其作者在最終對官方 protobuf 庫最絕望的一個事情,莫過于他朝朝暮暮,但官方一直不愿支持的標簽注入功能。這也是很多人使用 gogo/protobuf 的原因。

如下圖所示:

圖片圖片

標簽注入是什么功能

我們來看看 gogo/protobuf 擴展(包含自定義結構注入標簽功能),這是 gogo 的王牌功能之一,這是他的介紹:

圖片圖片

其在 gogo.proto[1] 支持了各種各樣的 EnumOptions、FileOptions、MessageOptions、FieldOptions 等。

我們最常見編碼訴求是調整生成 struct 時字段的 JSON tag,對應 jsontag 的功能:

圖片圖片

Proto 定義示例:

message Person {
  string name = 1;
  int32 id = 2 [(gogoproto.jsontag) = "id"];  // Unique ID number for this person.
  string email = 3;

  enum PhoneType {
    MOBILE = 0;
    HOME = 1;
    WORK = 2;
  }

  message PhoneNumber {
    string number = 1;
    PhoneType type = 2;
  }

  repeated PhoneNumber phones = 4;

  google.protobuf.Timestamp last_updated = 5;
}

通過 protoc 和 plugin 生成后的 Go 代碼:

type Person struct {
 Name        string                 `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"`
 Id          int32                  `protobuf:"varint,2,opt,name=id,proto3" json:"id"`
 Email       string                 `protobuf:"bytes,3,opt,name=email,proto3" json:"email,omitempty"`
 Phones      []*Person_PhoneNumber  `protobuf:"bytes,4,rep,name=phones,proto3" json:"phones,omitempty"`
 LastUpdated *timestamppb.Timestamp `protobuf:"bytes,5,opt,name=last_updated,jsnotallow=lastUpdated,proto3" json:"last_updated,omitempty"`
}

生成后的結構體中的 Id 字段,json tag 值為 id,沒有了 omitempty。可以解決很多同學在與前端對接時的一些煩惱。

圖片圖片

除此之外還有很多用法,有興趣的同學可以詳細查看 More Canonical Go Structures[2]。

為什么官方不支持

那為什么 golang/protobuf 一直不支持這些 protobuf 的擴展功能特性呢?

圖片圖片

直接明確拒絕,引來社區大范圍表情反對。(并沒有什么用)。

具體 golang/protobuf 不支持的原因,其項目成員在社區的多年爭斗下,給出了相對明確的答復。

如下圖所示:

圖片圖片

圖片圖片

  • 這個功能在 Go 語言中非常實用,官方承認且認可。
  • 如果調整或支持此功能,均超出了 golang/protobuf 包的適用范圍。因為官方包的定義是不與某一門編程語言強相關。
  • 如果 golang/protobuf 實現了這個功能,會出現其他語言無法有效利用此特性的情況。

說白了,官方覺得這個特性太 Go 語言定制化了,不愿意支持。

有什么替代方案

雖然現在 gogo 這一個開源項目已經進入廢棄階段,但根據 issues 內推薦的情況。可以選擇繼續使用 gogo,或者使用 protoc-go-inject-tag[3] 這一個項目。

簡單例子,Proto 定義:

// file: test.proto
syntax = "proto3";

package pb;
option go_package = "/pb";

message IP {
  // @gotags: valid:"ip"
  string Address = 1;

  // Or:
  string MAC = 2; // @gotags: validate:"omitempty"
}

通過 protoc 和 plugin 生成后的 Go 代碼:

type IP struct {
 // @gotags: valid:"ip"
 Address string `protobuf:"bytes,1,opt,name=Address,jsnotallow=address" json:"Address,omitempty" valid:"ip"`
}

可以明確看懂 json tag 多了 valid:"ip",符合我們在 proto 文件中聲明的注解訴求。

總結

通過兩篇文章梳理下來,對于整個前因后果和功能特性,我們都有了相對全面的學習和了解了。

官方 golang/protobuf 固然有自己的原則,社區也有自己的需求。開源的項目過大了,長年累月下來會難維護。

可能像 protoc-go-inject-tag 這種較為單一職責的開源庫,會活的更好,也會更好找到新的人銜接。也是一個不錯的方向。

參考資料

[1]gogo.proto: https://github.com/gogo/protobuf/blob/master/gogoproto/gogo.proto

[2]More Canonical Go Structures: https://github.com/gogo/protobuf/blob/master/extensions.md#more-canonical-go-structures

[3]protoc-go-inject-tag: https://github.com/favadi/protoc-go-inject-tag

責任編輯:武曉燕 來源: 腦子進煎魚了
相關推薦

2025-06-26 02:22:00

GoProtobuf標簽

2021-10-27 07:15:36

Go 循環引用

2021-12-09 10:51:47

Go繼承

2021-12-15 07:49:22

Go語言設計

2024-01-01 08:10:40

Go語言map

2024-01-05 08:45:35

Go語言map

2023-01-28 08:05:32

轉換Go泛型

2021-11-08 11:02:01

Go函數重載

2023-02-26 23:36:08

PHPGo函數

2024-03-08 08:51:59

Gomain函數

2020-07-22 08:01:41

Python開發運算符

2020-10-09 06:48:19

Pythonswitch語句

2024-03-12 09:13:28

Go語言main

2021-02-01 13:53:53

StringlongJava

2021-07-13 08:09:34

微博推特評論

2023-04-03 11:21:29

PythonGoRust

2009-03-12 08:42:38

AndroidWMMTK

2021-06-11 00:03:31

鴻蒙智能手機

2021-08-02 09:31:20

Python工具代碼

2014-06-05 15:16:49

Linux開源Flash
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久亚洲欧美日韩精品专区 | 国精久久 | 亚洲精品在线免费播放 | 国产欧美一区二区三区另类精品 | 久国产视频 | 欧美成人免费在线视频 | 日韩免费一二三区 | 国产精品一区二区三区在线播放 | 日本福利视频 | www.色综合| 午夜欧美| 成人精品一区二区 | 久久国产精品视频 | 久久精品国产a三级三级三级 | h片免费在线观看 | 91 在线| 视频一区二区国产 | 日本免费一区二区三区 | 91看片在线 | 日韩免费在线观看视频 | 免费视频久久 | 国产成人精品区一区二区不卡 | 欧美综合国产精品久久丁香 | 精品一区二区三区在线观看国产 | 国产精品永久在线观看 | 国产精品欧美一区二区三区 | 亚洲人成一区二区三区性色 | 美女视频一区二区三区 | 天天干天天插 | 国产精品亚洲一区二区三区在线 | 国产免费福利小视频 | 国产精品美女一区二区三区 | 在线资源视频 | 奇米影视77 | 日本三级在线 | h片在线观看网站 | 国产精品久久久久久久久久 | 成人av免费播放 | 久久青青 | 中文字幕在线免费观看 | 国产一区二区免费在线 |