学习了下protobuf这个工具,可以用来序列化数据结构,而且效率很高,数据可以压缩的更小。
记录下,我这里主要在C#里使用,从NuGet程序包安装以下两个
安装好后可以在该程序目录找到 packages\Google.Protobuf.Tools.3.26.1\tools\windows_x64
里的protoc.exe 这是一个编译器,用来编译proto文件,可以用它来生成对应数据结构的源代码。
例如:编写一个test.proto文件,里面定义了一个TestContact的数据结构
syntax = "proto3";
option cc_enable_arenas = true;package Test;message TestContact {int32 ID = 1;string Address = 2;string Name = 3;
}
新建两个文件夹src 和gen,将proto文件放到src文件夹中, 用protoc.exe编译它
protoc.exe --proto_path=src --csharp_out=gen test.proto
在gen文件夹中会得到一个cs文件。
项目中添加该cs文件,就可以对TestConcat此数据结构序列化和反序列化了
序列化并保存本地过程
TestContact t=new TestContact();
t.ID = 1;
t.Name = "qq";
t.Address = "aaa";//序列化
byte[] data=t.ToByteArray();// 将序列化的数据保存到文件
File.WriteAllBytes("person.bin", data);
从本地文件读出并反序列化
byte[] data = File.ReadAllBytes("person.bin");// 反序列化
TestContact person = TestContact.Parser.ParseFrom(data);