protojson简介
1.iota简介2.go generate命令简介3.golang uuid库介绍4.gRPC基本教程5.protolator简介6.Govulncheck v1.0.0 发布了!7.每日一库:GORM简介8.Go泛型简介9.Go 1.21发布!10.Golang zip压缩文件读写操作11.本地搭建playground12.zap自定义日志级别13.Gorm日志设置14.gin启动https支持15.Go Plugin介绍16.Golang漏洞管理17.可以丢掉123456了18.如何优雅地退出程序19.PGO前瞻20.go多版本管理21.openAI发布v0.2.0了22.Gin中间件开发23.Fabric区块链浏览器(1)24.每日一库:Memcache
25.protojson简介
26.每日一库:gosec27.Fabric区块链浏览器(2)28.每日一库:fsnotify简介29.gRPC with JWT30.embed简介31.Fabric区块链浏览器(3)32.每日一库:pprof简介33.go 1.21:cmp34.完全可复制、经过验证的 Go 工具链35.PGO in Go 1.2136.Fabric 2.x 智能合约开发记录37.为不断增长的Go生态系统扩展gopls38.每日一库:lumberjack -- 日志轮换和管理39.2023-04-26-微信安全模式下消息解析40.WASI support in Go41.每日一库:Prometheus42.如何实现流量控制和熔断降级?43.消息队列 - RabbitMQ44.Go 1.22 中的 For 循环45.设计模式之单例模式46.每日一库:使用Viper处理Go应用程序的配置47.使用 gopkg.in/yaml.v3 解析 YAML 数据48.在Go中如何实现并发49.解析类型参数50.设计模式之工厂模式51.每日一库:cobra 简介52.slices in Go 1.2153.go defer简介54.slice简介55.Golang Map底层实现简述56.Go 如何实现多态57.查找数组中第K大的元素58.go中的内存逃逸59.数组 vs. 切片60.队列(Queue):先进先出(FIFO)的数据结构61.go 中如何实现定时任务62.go 中的循环依赖63.Go中字符串处理:fmt.Sprintf与string.Builder的比较64.理解Go中的零值65.go 上下文:context.Context66.go中异常处理流程67.Go实现网络代理68.Why gRPC ?69.Go:条件控制语句70.Go 获取 IP 地址71.Golang并发控制方式有几种?72.Golang面试:泛型73.LRU算法简介74.MRU算法实现75.ARC算法实现76.Go语言中的交互式CLI开发:survey库简介77.C如何调用Gogoogle.golang.org/protobuf/encoding/protojson
是 Go 语言中的一个库,用于处理 Protocol Buffers(protobuf)和 JSON 之间的转换,遵循https://protobuf.dev/programming-guides/proto3#json实现。
以下是该库的一些主要功能:
- 将 protobuf 消息转换为 JSON 格式:这是通过
Marshal
或MarshalOptions.Marshal
函数实现的。这些函数接收一个 protobuf 消息并返回一个 JSON 格式的字符串。 - 将 JSON 格式的数据转换为 protobuf 消息:这是通过
Unmarshal
或UnmarshalOptions.Unmarshal
函数实现的。这些函数接收一个 JSON 格式的字符串和一个 protobuf 消息的指针,然后将 JSON 数据解析并填充到 protobuf 消息中。 - 自定义 JSON 编码和解码的行为:
MarshalOptions
和UnmarshalOptions
结构体提供了一些选项,可以用来自定义 JSON 编码和解码的行为。例如,可以通过EmitUnpopulated
选项控制是否输出未设置的字段,通过UseProtoNames
选项控制是否使用 protobuf 字段的原始名称作为 JSON 字段的键。 - 支持 Well-Known Types:该库提供了对 protobuf 的 Well-Known Types 的特殊处理,例如
Timestamp
、Duration
、Struct
、Value
等。
接下来我们以下面的 .proto
为例,介绍下如何使用 google.golang.org/protobuf/encoding/protojson
,并简单对比下 proto
、 protojson
和 encoding/json
三者之间的性能对比:
syntax = "proto3"; package example.pb; option go_package = "./;pb"; import "google/protobuf/struct.proto"; message Base { string tx_hash = 1; int64 timestamp = 2; google.protobuf.Struct extra = 3; uint64 block_number = 4; int32 category = 5; } message CertGen { string id = 1; string issuer = 2; string name = 3; string number = 4; string seal_name = 5; string seal_number = 6; string sign_hash = 7; string date = 8; Base base = 9; }
func genData() *pb.CertGen { data := map[string]interface{}{ "name": "1234", "age": 12, "score": 1345.452434, } extra, _ := structpb.NewStruct(data) base := &pb.Base{ TxHash: "1234556", Timestamp: 1234566, Extra: extra, BlockNumber: 123456, Category: 4, } return &pb.CertGen{ Id: uuid.NewString(), Issuer: uuid.NewString(), Name: uuid.NewString(), Number: uuid.NewString(), SealName: uuid.NewString(), SealNumber: uuid.NewString(), SignHash: uuid.NewString(), Date: time.Now().Format(time.DateTime), Base: base, } } func BenchmarkProto(b *testing.B) { gen := genData() for i := 0; i < b.N; i++ { proto.Marshal(gen) } } func BenchmarkProtoJson(b *testing.B) { gen := genData() for i := 0; i < b.N; i++ { protojson.Marshal(gen) } } func BenchmarkStdJson(b *testing.B) { gen := genData() for i := 0; i < b.N; i++ { json.Marshal(gen) } }
结果如下:
$ go test -bench=. goos: linux goarch: amd64 pkg: example cpu: 12th Gen Intel(R) Core(TM) i7-1260P BenchmarkProto-16 817065 1412 ns/op BenchmarkProtoJson-16 218583 5372 ns/op BenchmarkStdJson-16 343822 3216 ns/op PASS ok example 3.554s

声明:本作品采用署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)进行许可,使用时请注明出处。
Author: mengbin
blog: mengbin
Github: mengbin92
cnblogs: 恋水无意
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程