C#中使用ProtoBuf提高序列化速度对比二进制序列化
场景
ProtoBuf
protocolbuffer是google 的一种数据交换的格式,它独立于语言,独立于平台。
google 提供了多种语言的实现:java、c#、c++、go 和 python,每一种实现都包含了相应语言的编译器以及库文件。
由于它是一种二进制的格式,比使用xml 进行数据交换快许多。可以把它用于分布式应用之间的数据通信或者异构环境下的数据交换。
作为一种效率和兼容性都很优秀的二进制数据传输格式,可以用于诸如网络传输、配置文件、数据存储等诸多领域。
.proto
类似于.json和.xml,ProtoBuf有自己的文件格式.proto文件格式。
也有自己的语法,具体可以搜索.proto语法。
示例源码下载
https://download.csdn.net/download/badao_liumang_qizhi/11583786
实现
新建.proto文件
这里使用的是EditPlus新建txt文件,按照其语法要求编写如下request.proto文件。
package ProtoBufTest;message Request {required int32 id = 1;required string password = 2;
}
注:
package ProtoBufTest 要与项目的namespace相对应。
message 后面就是要生成的类名。
required表示必须的,int32对应int类型,string对应string类型。
=1是固定的语法格式,记得往后递增。
最终文件如下
.ptoto文件生成类(.cs文件)
生成工具ProtoGen下载:
https://download.csdn.net/download/badao_liumang_qizhi/11583806
将上面新建的文件放在与protogen.exe同目录下
然后在此处打开命令行(Windows下是按住shift,在当前目录右击选择在此处打开命令行)。
输入命令:
protogen.exe -i:request.proto -o:Request.cs
注:
-i后面跟的是上面新建的proto文件
-o后面跟的是要生成的.cs文件
运行后会在同目录下生成Request.cs
生成的文件内容
//------------------------------------------------------------------------------
// <auto-generated>
// This code was generated by a tool.
//
// Changes to this file may cause incorrect behavior and will be lost if
// the code is regenerated.
// </auto-generated>
//------------------------------------------------------------------------------// Generated from: request.proto
namespace ProtoBufTest
{[global::System.Serializable, global::ProtoBuf.ProtoContract(Name=@"Request")]public partial class Request : global::ProtoBuf.IExtensible{public Request() {}private int _id;[global::ProtoBuf.ProtoMember(1, IsRequired = true, Name=@"id", DataFormat = global::ProtoBuf.DataFormat.TwosComplement)]public int id{get { return _id; }set { _id = value; }}private string _password;[global::ProtoBuf.ProtoMember(2, IsRequired = true, Name=@"password", DataFormat = global::ProtoBuf.DataFormat.Default)]public string password{get { return _password; }set { _password = value; }}private global::ProtoBuf.IExtension extensionObject;global::ProtoBuf.IExtension global::ProtoBuf.IExtensible.GetExtensionObject(bool createIfMissing){ return global::ProtoBuf.Extensible.GetExtensionObject(ref extensionObject, createIfMissing); }}}
项目中引进
新建窗体项目,然后将上面生成的Request.cs文件复制到项目下。
此时打开cs文件会报错,此时需要引进dll(动态链接库文件)--protobuf-net.dll。
protobuf-net.dll下载:
https://download.csdn.net/download/badao_liumang_qizhi/11583772
添加引用
打开资源管理器--右击引用--添加
选择浏览--右下角浏览--确定
实现ProtoBuf序列化
打开窗体设计器,拖拽一个按钮Button,然后双击按钮进入其点击事件。
private void button1_Click(object sender, EventArgs e){//序列化操作Request request = new Request();request.id = 1;request.password = "123";//计时器计时Stopwatch sw = new Stopwatch();//启动计时器sw.Start();//执行序列化MemoryStream ms = new MemoryStream();Serializer.Serialize<Request>(ms, request);byte[] data = ms.ToArray();//停止计时器sw.Stop();//输出计时时间Console.WriteLine("使用ProtoBuf序列化:" + sw.Elapsed); }
注:
在上面调用Serializer时引入的是ProtoBuf自带的。
对比二进制序列化
右击项目-添加-类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace ProtoBufTest
{[Serializable]class Person{public Person(int id ,string password) {this.Id = id;this.Password = password;}private int id;public int Id{get { return id; }set { id = value; }}private string password;public string Password{get { return password; }set { password = value; }}}
}
注:记得要添加可序列化的标识[Serializable]
在上面的窗体中在拖拽一个Button,双击进入其点击事件。
private void button2_Click(object sender, EventArgs e){Person per = new Person(18,"张三");//计时器计时Stopwatch sw = new Stopwatch();sw.Start();FileStream fs = new FileStream(filePath, FileMode.Create);BinaryFormatter bf = new BinaryFormatter();bf.Serialize(fs, per);fs.Close();sw.Stop();Console.WriteLine("二进制序列化:" + sw.Elapsed);}
对比效果
运行项目,先点击二进制序列化按钮,再点击ProtoBuf序列化按钮。
C#中使用ProtoBuf提高序列化速度对比二进制序列化相关推荐
- C#中使用ProtoBuf将list进行序列化并保存到文件
场景 C#中使用ProtoBuf提高序列化速度对比二进制序列化: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/99850052 ...
- php protobuf 二进制,PHP环境中使用ProtoBuf数据格式
1.syntax="proto3":表明使用的是proto3格式,如果不指定则为proto2 2.package test:定义包名为test,生成类时,会产生一个目录为test ...
- ProtoBuf的介绍以及在Java中使用protobuf将对象进行序列化与反序列化
场景 ProtoBuf简介 protocol buffers 是一种语言无关.平台无关.可扩展的序列化结构数据的方法,它可用于(数据)通信协议.数据存储等. Protocol Buffers 是一种灵 ...
- net自带二进制序列化,XML序列化和ProtoBuf序列化的压缩对比
测试结果: ProtoBuf Length:115 BinaryFormatter Length:1177 XmlSerializer Length:814 xml length:825 做了一个各种 ...
- Beetle在Tcp通讯中使用Protobuf
Protobuf是google制定的一种对象序列化格式,而在.net下的实现有protobuf-net.而protobuf-net在序列化方面有着出色的性能,效率是.net二进制序列化几倍,而序列化后 ...
- 在Go中使用Protobuf
本教程使用proto3版本的protocol buffer语言,提供了一个基本的在Go程序中使用protocol buffer的介绍.通过创建一个简单的示例应用程序,向你展示如何 在 .proto文件 ...
- 在Golang中使用Protobuf
本教程使用proto3版本的protocol buffer语言,提供了一个基本的在Go程序中使用protocol buffer的介绍.通过创建一个简单的示例应用程序,向你展示如何 在.proto文件中 ...
- Unity中的资源管理-几种常见的序列化方式
本文分享Unity中的资源管理-几种常见的序列化方式 在网游客户端的开发中, 大部分数据只需要从服务器获取数据之后存放在内存中, 但是仍然有一些数据需要做序列化, 并持久化存放在客户端本地. 比如用户 ...
- 自行实现比dotcore/dotnet更方便更高性能的对象二进制序列化
二进制序列化可以方便快捷的将对象进行持久化或者网络传输,并且体积小.性能高,应用面甚至还要高于json的序列化:开始之前,先来看看dotcore/dotne自带的二进制序列化:C#中对象序列化和反序列 ...
最新文章
- VMware Workstation 6.0全貌概览
- android canves rotate 详解
- 人脸检测算法_目前最强!开源人脸检测算法:RetinaFace
- C++又一坑:动态链接库中的全局变量
- javamail课设_JAVA MAIL实例讲解教程视频下载(16课程)
- 类模板static成员的使用
- hdu 4280 最大流sap
- optimize table优化mysql例子
- 飞龙的程序员书单 – 前端
- 20-30-010-安装-kafka-manager
- 【spark】Spark的介绍、安装以及配置相关介绍
- Redis基础(三)——数据类型
- photoshop 插件_什么是Photoshop插件,扩展程序和附加组件?
- 三种1:4传输线变压器巴伦的分析
- 关于QQ热键在不知道的情况下找出热键组合的办法
- vsftp配置虚拟账户
- python-docx文档高亮显示
- Android 装置CTS与GMS认证差异
- SQL Server 2008 (2008 R2) 清理日志方法
- 拼多多店铺怎么做产品
热门文章
- Linux运维:ulimit命令修改打开文件的句柄数
- php在双引号中输出变量要加大括号,php中输出变量加大括号{}作用_PHP教程
- .net一个函数要用另一个函数的值_【195期】MySQL中的条件判断函数 CASE WHEN、IF、IFNULL你会用吗?...
- 计算机硬件耗电,电脑中最耗电的三个硬件排行:这答案意料之外的情理之中!...
- php图片生成缩略图_PHP实现生成图片缩略图函数
- python滑动验证码处理_python+selenium滑动式验证码解决办法
- 电脑看书软件_能全平台阅读的图书软件,是kindle? No!大公司低调出品
- 乐视html5,乐视杨永强:Letv Store为HTML5开发者带来新机遇
- java用不用stream_Java parallelStream不使用预期的线程数
- java虚成员函数_Java常见知识点汇总(④)——虚函数、抽象函数、抽象类、接口...