Unity手游之路<二>Java版服务端使用protostuff简化protobuf开发

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

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

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

等,不一而足。

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

  • 传统方式

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

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

[plain] view plaincopy

  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] view plaincopy

  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] view plaincopy

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

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

[java] view plaincopy

  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 = "[email protected]";
  8. // 缓存buff
  9. LinkedBuffer buffer = LinkedBuffer.allocate(1024);
  10. // 序列化成protobuf的二进制数据
  11. byte[] data = ProtobufIOUtil.toByteArray(person1, schema, buffer);
  12. // 反序列化
  13. Person person2 = new Person();
  14. ProtobufIOUtil.mergeFrom(data, person2, schema);
  15. System.out.println(person2.id);
  16. }

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

  • 性能考虑

一开始,考虑到Protostuff的这种反射,会不会比官方推荐的反射性能差很远呢?没有调查,就没有发言权。有人已经测试了,性能方面还是差不多的,可以放心使用。
具体的测试数据可以去查阅网上相关的数据,在此省略了。

  • 总结

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

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

时间: 2024-10-03 21:54:14

Unity手游之路<二>Java版服务端使用protostuff简化protobuf开发的相关文章

Unity手游之路&lt;十三&gt;手游代码更新策略探讨

这几个月公司项目非常忙,加上家里事情也多,所以blog更新一直搁置了.最近在项目开发上线过程中遇到了一些新问题,接下来的时间和大家多多探讨学习.大家在工作中遇到技术问题,或者有什么想分享的,欢迎多多探讨 [email protected] ----------------------------------------------------------------------------------------------------------------------------------

Unity手游之路&lt;十二&gt;手游资源热更新策略探讨

http://blog.csdn.net/janeky/article/details/17666409 上一次我们学习了如何将资源进行打包.这次就可以用上场了,我们来探讨一下手游资源的增量更新策略.注意哦,只是资源哦.关于代码的更新,我们稍后再来研究.理论上这个方案可以使用各种静态资源的更新,不仅仅是assetbundle打包的. (转载请注明原文地址http://blog.csdn.net/janeky/article/details/17666409) 原理 现在的手游安装有几种方式.一种

Unity手游之路&lt;三&gt; 基于Unity+Java的聊天室源码

http://blog.csdn.net/janeky/article/details/17233199 项目介绍 这是一个简单的Unity项目,实现最基本的聊天室群聊功能.登录聊天室后,用户可以输入信息进行发言,其他人可以收到消息.玩家还可以更改昵称.项目详细描述的前后端Socket通信,编码,解析二进制流的过程. 这个项目的主要目标有几个: 1.实现Unity的前后端通信进制          2.学习Protobuf的应用 最终的效果 前端            a.网络通信NetClie

Unity手游之路&lt;六&gt;游戏摇杆之Easy Touch 3教程

之前已经介绍过Unity自带的摇杆Joystick,它用起来很简单.但是它也存在很多局限,不能全部满足普通mmo手游的一些需求,例如:要能方便地更好素材:能指定在某个区域显示,或者只有在该区域触摸时才出现等等.而这些功能,Easy Touch插件都已经帮你实现了.全部是可配置.大家可以从Asset Store上购买,或者使用free版. (可随意分享,请注明原文出处http://blog.csdn.net/janeky/article/details/17364903) 实例 还是用上次例子来实

Unity手游之路手游代码更新策略探讨

版权声明: https://blog.csdn.net/janeky/article/details/25923151 这几个月公司项目非常忙.加上家里事情也多,所以blog更新一直搁置了. 近期在项目开发上线过程中遇到了一些新问题,接下来的时间和大家多多探讨学习. 大家在工作中遇到技术问题,或者有什么想分享的,欢迎多多探讨 ken@iamcoding.com. -------------------------------------------------------------------

Unity手游之路&lt;八&gt;自动寻路Navmesh之入门

http://blog.csdn.net/janeky/article/details/17457533 在的大部分mmo游戏都有了自动寻路功能.点击场景上的一个位置,角色就会自动寻路过去.中间可能会有很多的障碍物,角色会自动绕过障碍物,最终达到终点.使用Unity来开发手游,自动寻路可以有很多种实现方式.第一种比较传统的是使用A星寻路,它是一种比较传统的人工智能算法,在游戏开发中比较常用到.大部分的页游和端游都用到这种技术.在Unity游戏也可以用这种技术,Asset Store上面已经有相关

Unity手游之路&lt;十&gt;自动寻路Navmesh之跳跃,攀爬,斜坡

http://blog.csdn.net/janeky/article/details/17598113 在之前的几篇Blog总,我们已经系统学习了自动寻路插件Navmesh的相关概念和细节.然而,如果要做一个场景精美的手游,需要用到各种复杂的场景地形,而不仅仅是平地上的自动寻路.今天我们将通过一个完整的复杂的实例,来贯穿各个细节.我们将实现一个复杂的场景,角色可以在里面攀爬,跳跃,爬坡.是不是感觉很像当年的CS游戏呢?本案例将会用得一些基本的动画函数,大家可以先结合文档有个大概的了解.本实例是

Unity手游之路&lt;一&gt;C#版本Protobuf

http://blog.csdn.net/janeky/article/details/17104877 个游戏包含了各种数据,包括本地数据和与服务端通信的数据.今天我们来谈谈如何存储数据,以及客户端和服务端的编码方式.根据以前的经验,我们可以用字符串,XML,json...甚至可以直接存储二进制.各种方式都有各自的优劣,有些性能比较好,但是实现方式比较麻烦.有些数据冗余太多. 简介 今天我们来学习一种广泛使用的数据格式:Protobuf.简单来说,它就是一种二进制格式,是google发起的,目

Unity手游之路&lt;九&gt;自动寻路Navmesh之高级主题

http://blog.csdn.net/janeky/article/details/17492531 之前我们一起学习了如何使用Navmesh组件来实现最基本的角色自动寻路.今天我们再继续深入探索Navigation组件的高级功能.在本文中,你将了解到如何在两个隔离层自动生成寻路网格?如何手动指定寻路网格的路线?以及寻路网格层的应用.(本文所用到的模型皆来自Unity3d官网). (转载请注明原文地址http://blog.csdn.net/janeky/article/details/17