博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Unity手游之路<二>Java版服务端使用protostuff简化protobuf开发
阅读量:6263 次
发布时间:2019-06-22

本文共 1997 字,大约阅读时间需要 6 分钟。

http://blog.csdn.net/janeky/article/details/17151465

开发一款网络游戏,首先要考虑的是客户端服务端之间用何种编码格式进行通信。之前我们介绍了Unity游戏前端使用protobuf的方法。今天我们来谈谈服务端如何使protobuf。游戏服务端语言百花齐放,除了比较传统的c/c++外,Java,Erlang,Python都有很多团队在使用。

 

今天推荐一下Java作为服务端开发语言。国内很多出色的页游和手游都是采用Java作为服务端语言的。比如《神曲》《秦美人》《龙将》《时空猎人》

等,不一而足。

 

本文主要探讨如何简化Protobuf程序的开发。

  • 传统方式

按照传统的开发流程,都是如下:

 

1.先编写proto文件格式,例如

 

[plain] 
 
  1. message Person {  
  2.   required int32 id = 1;  
  3.   required string name = 2;  
  4.   optional string email = 3;  
  5. }  

 

2.运行编译程序,生成实体类Person.java
protoc  --java_out=./src   ./person.proto
3.在程序中可以直接使用Person类的相关函数进行序列化和反序列化

 

[java] 
 
  1. //序列化  
  2. Person person = builder.build();  
  3. byte[] buf = person.toByteArray();  
  4. //反序列化  
  5. Person person2 = PersonProbuf.Person.parseFrom(buf);  

 

上面的流程看似很方便了,有什么问题呢?还能不能再改进呢?我们先看看生成的Person类代码吧,竟然有几千行。

实际上我们只是包含了3个变量而已,可读性大大降低了。其次,开发过程每次都得借助外部的编译工具来生成代码。
于是我们可能就有了一个简单的思路。自己编写Person的类,然后通过外部的api,直接对这个类进行序列化和反序列化。
直接抛弃了protoc工具。
这个思路,已经有人实现出来了,最早是在c#语言版本的protobuf-net实现了。它利用c#的Attribute(类似Java的Annotation注解)+反射来实现普通实体类的Protobuf序列化和
反序列化。
本想自己把protobuf-net的c#代码转换成Java代码。后来在OverStack中翻到有人介绍Protostuff,正是基于这种思路的。

  • 改进版

1.编写Person类(为了使demo代码精简,字段都暂时设为public)

[java] 
 
  1. public class Person{  
  2.     public int id;  
  3.     public String name;  
  4.     public String email;  
  5. }  

2.测试序列化和反序列化

[java] 
 
  1. public static void main(String[] args) throws IOException {  
  2.         // //类的模式设置为Person类  
  3.         Schema<Person> schema = RuntimeSchema.getSchema(Person.class);  
  4.         Person person1 = new Person();  
  5.         person1.id = 10086;  
  6.         person1.name = "ken";  
  7.         person1.email = "ken@iamcoding.com";  
  8.         // 缓存buff  
  9.         LinkedBuffer buffer = LinkedBuffer.allocate(1024);  
  10.         // 序列化成protobuf的二进制数据  
  11.         byte[] data = ProtobufIOUtil.toByteArray(person1, schema, buffer);  
  12.   
  13.   
  14.         // 反序列化  
  15.         Person person2 = new Person();  
  16.         ProtobufIOUtil.mergeFrom(data, person2, schema);  
  17.         System.out.println(person2.id);  
  18.     }  

更多的功能可以去详细阅读相关的手册吧。比如,指定实体类字段的序列化顺序,忽略某些字段不被序列化等等。

  • 性能考虑

一开始,考虑到Protostuff的这种反射,会不会比官方推荐的反射性能差很远呢?没有调查,就没有发言权。有人已经测试了,性能方面还是差不多的,可以放心使用。

具体的测试数据可以去查阅网上相关的数据,在此省略了。

  • 总结

Protostuff的优势是将开发流程简化,让我们可以更高效,更专注地开发。有任何问题欢迎一起探讨ken@iamcoding.com

 

下一篇,我将会用一个完整的demo,将整个Unity客户端和服务端的通信流程串联起来。

你可能感兴趣的文章
MVC项目中怎样用JS导出EasyUI DataGrid为Excel
查看>>
制作个人开发IDE
查看>>
给架构师骂了
查看>>
ajax提交form表单资料详细汇总
查看>>
Excel——使用INDEX和SMALL实现条件筛选
查看>>
c#迭代器 转载
查看>>
JQuery与JavaScript
查看>>
Jmeter--正则表达式提取器
查看>>
设置Slider Control 控件的取值范围
查看>>
struts2 启动tomcat时报错:org.apache.catalina.core.StandardContext filterStart
查看>>
asp.net导入后台代码
查看>>
java web dev知识积累
查看>>
Flex 经纬度匹配正则表达式
查看>>
在SSIS包中使用 Checkpoint从失败处重新启动包[转]
查看>>
为什么开通博客?
查看>>
深入浅出Mybatis系列(四)---配置详解之typeAliases别名(mybatis源码篇)
查看>>
LVS+Keepalived实现高可用负载均衡(转)
查看>>
Django学习【第14篇】:Django之Form组件补充
查看>>
在web.xml中配置初始化参数
查看>>
Java多线程下 ThreadLocal 的应用实例
查看>>