当前位置: 首页 > news >正文

自己做的简单网站下载深圳公司查询

自己做的简单网站下载,深圳公司查询,wordpress手机浏览,wordpress 转换 织梦各位准备好了吗#xff01;这一次#xff0c;我们将深入探讨 Protocol Buffers#xff08;protobuf#xff09;及其在数据序列化中的超能力所在。 介绍 Protocol Buffers#xff0c;也被称为 protobuf#xff0c;是由谷歌开发的一种语言无关的二进制序列化格式。其主要…各位准备好了吗这一次我们将深入探讨 Protocol Buffersprotobuf及其在数据序列化中的超能力所在。 介绍 Protocol Buffers也被称为 protobuf是由谷歌开发的一种语言无关的二进制序列化格式。其主要目的是为了高效地序列化结构化数据用于系统间通信和数据存储。 Protocol Buffers 的主要优势 紧凑性Protobuf 提供高效的序列化生成较小的消息大小提升带宽利用效率。模式演进Protobuf 支持模式演进而不破坏兼容性允许对数据结构进行无缝更新。高效的序列化和反序列化Protobuf 提供快速高效的序列化提升整体系统性能。跨平台支持Protobuf 允许不同平台和语言之间无缝交换数据。 这些优势使得 Protobuf 成为在 Go 应用程序中进行高效数据通信和存储的强大工具。 它比 JSON 和 XML 更好的地方 XML即可扩展标记语言就像一张地图用标签帮助组织和结构化数据。它以一种人类和机器都能理解的方式呈现信息。然而XML 可能冗长并占用更多空间这可能降低性能使数据传输效率降低。 JSON即 JavaScript 对象表示法就像一个信使使用简单的键值结构来表示数据对象。它因易于阅读和使用而在 Web 服务之间传输数据时变得流行。但 JSON 的基于文本的格式可能导致更大的文件大小从而影响数据传输速度。 相比之下Protocol Buffersprotobuf在数据序列化领域脱颖而出。它就像一个魔术将数据转换为紧凑高效的二进制格式。Protobuf 以快速的数据处理和适应变化的数据结构而闻名并且在不破坏兼容性的情况下进行操作。它可以与不同的编程语言一起使用并确保数据的可靠性。 总之XML 和 JSON 各有用途但如果您需要强大且高效的数据序列化解决方案Protocol Bufferprotobuf是首选。它提供紧凑性、速度、灵活性和兼容性使其成为高效处理数据的首选方案。 在 Golang 中的序列化性能Protocol Buffers vs. JSON 言归正传让我们动手实践。 访问官方 Protocol Buffers GitHub 仓库https://github.com/protocolbuffers/protobuf下载与您操作系统兼容的编译器。使用 .proto 文件格式定义一个 Protocol Buffers 消息模式。 syntax proto3; package main; option go_package /;msgmodel;message MyMessage {int32 id 1;string name 2;string email 3; }编译文件 protoc — go_out. ./*proto 这个命令从 protobuf 模式生成 Go 代码绑定。--go_out 标志指定输出应为 Go 语言。这将生成一个 msg.pb.go 文件其中包含您的 protobuf 模式所需的代码绑定。 在 Golang 中实现一个基准测试使用 protobuf 和 JSON 对大型数据集进行序列化。 package mainimport (encoding/jsongithub.com/golang/protobuf/protogo-protobuf/model/messagelogtesting )const (iteration 10000000 //Number of iterations for the benchmark test )func generateDataset() []*message.MyMessage {var dataset []*message.MyMessagefor i : 0; i iteration; i {data : message.MyMessage{Email: johndoeexample.com,Name: John Doe,Id: int32(i),}dataset append(dataset, data)}return dataset }func BenchmarkProtobufSerialisation(b *testing.B) {dataset : generateDataset()b.ResetTimer()for n : 0; n b.N; n {for _, data : range dataset {_, err : proto.Marshal(data)if err ! nil {log.Fatal(err)}}} }func BenchmarkJSONSerialization(b *testing.B) {dataset : generateDataset()b.ResetTimer()for n : 0; n b.N; n {for _, data : range dataset {_, err : json.Marshal(data)if err ! nil {log.Fatal(err)}}} } func main() {// Run the benchmark teststesting.Benchmark(BenchmarkProtobufSerialisation)testing.Benchmark(BenchmarkJSONSerialization) }根据基准测试结果如下所示很明显就速度而言Protocol BuffersProtobuf的序列化性能优于 JSON。与 JSON 的序列化基准测试相比Protobuf 的序列化基准测试完成时间明显较短。 内存性能比较JSON vs. Protocol Buffers 在 Golang 中实现一个基准测试比较使用 Protocol Buffers 和 JSON 处理大型数据集时的内存使用情况。 package mainimport (encoding/jsongithub.com/golang/protobuf/protogo-protobuf/model/messagelogruntimeruntime/debugtesting )const (iteration 100000000 //Number of iterations for the benchmark test )func generateDataset() []*message.MyMessage {var dataset []*message.MyMessagefor i : 0; i iteration; i {data : message.MyMessage{Email: johndoeexample.com,Name: John Doe,Id: int32(i),}dataset append(dataset, data)}return dataset }func BenchmarkProtobufSerialisation(b *testing.B) {dataset : generateDataset()b.ResetTimer()for n : 0; n b.N; n {for _, data : range dataset {_, err : proto.Marshal(data)if err ! nil {log.Fatal(err)}}}measureMemoryUsage(b) }func BenchmarkJSONSerialization(b *testing.B) {dataset : generateDataset()b.ResetTimer()for n : 0; n b.N; n {for _, data : range dataset {_, err : json.Marshal(data)if err ! nil {log.Fatal(err)}}}measureMemoryUsage(b)} func measureMemoryUsage(b *testing.B) {debug.FreeOSMemory()var mem runtime.MemStatsruntime.GC()runtime.ReadMemStats(mem)b.ReportMetric(float64(mem.Alloc)/1024/1024, Memory_MB) }func main() {// Run the benchmark teststesting.Benchmark(BenchmarkProtobufSerialisation)testing.Benchmark(BenchmarkJSONSerialization)}尽管差异很小但基准测试结果表明与 Protobuf 序列化相比JSON 序列化使用了更多的内存。平均而言JSON 序列化消耗了约 0.2052 MB 的内存而 Protobuf 序列化仅使用了约 0.2042 MB。尽管差异很小但很明显 Protobuf 在内存使用方面更加高效。这意味着 Protobuf 的紧凑二进制格式有助于节省内存使其成为处理大型数据集和提高性能的良好选择。 结论 现在是总结的时候了 与在 Golang 中的 JSON 序列化相比Protocol Buffersprotobuf展现出了更优越的性能和内存效率。借助其紧凑的二进制格式和高效的序列化机制protobuf 提供了更小的消息大小、提升了网络效率并减少了带宽使用。此外其模式演进能力允许对数据模型进行无缝更新。虽然 JSON 有其优势但在需要高速和高内存效率的数据序列化场景中protobuf 出类拔萃实现了优化的数据传输和改善的系统性能。
http://www.huolong8.cn/news/148059/

相关文章:

  • 网页设计与网站建设论述题做网站推荐源创网络
  • pc 手机站网站制作企业建站公司报价
  • 东莞网站建设dgjwz网站网络架构
  • 网站备案时间多久云主机 网站指南
  • 珠海门户网站建设俄文网站建设方案
  • 网站建设需要哪些东西黄冈手机网站建设
  • 企业宣传注册哪些论坛 网站好wordpress 结构分析
  • 本地南昌网站建设太原网站建设网站
  • 源码网站程序最新的电商资讯有哪些
  • 用wordpress建一个网站吗网页设计图片超链接
  • 用自己服务器做网站网络营销案例分析模板
  • 网站建设方案范文1000字云南微网站制作
  • 帝国cms做的网站域名和服务器的关系
  • 太原的网站搭建公司备案的网站有什么好处
  • 上地网站制作营销型网站的建设
  • 长沙网站快速排名优化深圳网站建设服务哪一个便宜
  • 高端网站推广艺缘网站的建设
  • 盐城市网站o2o是指的是什么
  • 深圳高端建设网站怎样让网站显示网站建设中
  • 中山网站百度优化淘宝网络推广怎么做
  • 网站设计与规划作业黄骅市邮政编码
  • 永州建设公司网站08服务器做网站
  • 图书馆网站建设费用一站式网站建设价格
  • 杭州建设信用网新网站品优购网页制作代码
  • 深圳俄语网站建设皮具制品 东莞网站建设
  • 北京做网站的建立局域网的步骤
  • 网站建设合同的内容与结构网络策略
  • 绵阳的网站建设苏州网络推广公司永阳
  • 天河网站建设哪家强新网站建设方案
  • 合肥网站建设 微笑互联赣州信息港房产网