一直在物色比较好用的网络传输数据序列化工具,看了诸如marshalling,protobuff等,但是均有一个共同特点,使用起来异常繁杂,有没有比较好用同时性能又不会太差的组件呢?答案当然是有的,那就是基于protobuff改造的protostuff,它拥有良好性能的同时,又免去了生成描述文件的烦恼,可谓是趁手利器。

来看看具体的使用方式吧。

首先,引入maven依赖如下:

<dependency>
<groupId>io.protostuff</groupId>
<artifactId>protostuff-core</artifactId>
<version>1.4.4</version>
</dependency>
<dependency>
<groupId>io.protostuff</groupId>
<artifactId>protostuff-runtime</artifactId>
<version>1.4.4</version>
</dependency>

之后,编写序列化工具Util:

public class SerializeUtil {

    private static class SerializeData{
private Object target;
} @SuppressWarnings("unchecked")
public static byte[] serialize(Object object) {
SerializeData serializeData = new SerializeData();
serializeData.target = object;
Class<SerializeData> serializeDataClass = (Class<SerializeData>) serializeData.getClass();
LinkedBuffer linkedBuffer = LinkedBuffer.allocate(1024 * 4);
try {
Schema<SerializeData> schema = RuntimeSchema.getSchema(serializeDataClass);
return ProtostuffIOUtil.toByteArray(serializeData, schema, linkedBuffer);
} catch (Exception e) {
throw new IllegalStateException(e.getMessage(), e);
} finally {
linkedBuffer.clear();
}
} @SuppressWarnings("unchecked")
public static <T> T deserialize(byte[] data, Class<T> clazz) {
try {
Schema<SerializeData> schema = RuntimeSchema.getSchema(SerializeData.class);
SerializeData serializeData = schema.newMessage();
ProtostuffIOUtil.mergeFrom(data, serializeData, schema);
return (T) serializeData.target;
} catch (Exception e) {
throw new IllegalStateException(e.getMessage(), e);
}
}
}

需要注意的是RuntimeSchema.getSchema这块代码,通过翻看源码可以知道,里面已经放置了一个缓存map帮我们缓存生成的内容,所以不需要自己再加缓存了。

由于protostuff目前不支持序列化list等对象,所以需要使用普通的POJO包装一下。

最后,来写一个测试吧:

public static void main(String...args) throws Exception {

        User user = new User();
user.setUserId(123456);
user.setAddress("I am a good boy");
user.setNote("this is test"); List<String> list = new ArrayList<>();
list.add("record1");
list.add("record2");
list.add("record3");
user.setRecords(list); Teacher teacher1 = new Teacher();
teacher1.setName("语文老师");
Teacher teacher2 = new Teacher();
teacher2.setName("数学老师");
List<Teacher> teachers = new ArrayList<>();
teachers.add(teacher1);
teachers.add(teacher2);
user.setTeachers(teachers); byte[] b = serialize(user); User rst = deserialize(b, User.class); System.out.println(JSON.toJSONString(rst));
}
class User {
private Integer userId;
private String address;
private String note;
private List<String> records;
private List<Teacher> teachers; public Integer getUserId() {
return userId;
}
public void setUserId(Integer userId) {
this.userId = userId;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public String getNote() {
return note;
}
public void setNote(String note) {
this.note = note;
} public List<String> getRecords() {
return records;
} public void setRecords(List<String> records) {
this.records = records;
} public List<Teacher> getTeachers() {
return teachers;
} public void setTeachers(List<Teacher> teachers) {
this.teachers = teachers;
}
} class Teacher{
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}

最终的运行结果如下:

{"address":"I am a good boy","note":"this is test","records":["record1","record2","record3"],"teachers":[{"name":"语文老师"},{"name":"数学老师"}],"userId":123456}

可以看到,这种相对来说比较复杂的结构的序列化和反序列化,还是挺得心应手的。

参考:序列化利器-protostuff

最新文章

  1. Semaphore(计数信号量)
  2. JQuery 判断不同浏览器
  3. 《Java中的抽象类及抽象类的作用》
  4. 转:EF调用存储过程、函数
  5. 手动安装 mysqldb 与[ pip easy_install]
  6. 【转】[转]order by 1是什么意思?
  7. FlowPlayer 参数说明
  8. php 之 类,对象
  9. vs code调试console程序报错--preLaunchTask“build”
  10. 爬虫(五)requests模块2
  11. 【亲测】Java 接口自动化步骤
  12. Python Day 7
  13. [数学]MIT牛人解说数学体系
  14. java调用高德地图api实现通过ip定位访问者的城市
  15. C#学习笔记(33)——批量修改word标题
  16. Linux学习 :移植U-boot_2012.04.01到JZ2440开发板
  17. python连接Mongo数据库
  18. C++构造函数和析构函数执行顺序
  19. Hibernate 再接触 一对多单向关联
  20. Openwrt Support RESET Button (5)

热门文章

  1. LDAP&amp;IMPLEMENTATION
  2. tinkpad e450c 进入 BIOS
  3. Linux error numbers
  4. dataguard主库删除归档日志后从库恢复的方法
  5. 使用pynlpir增强jieba分词的准确度
  6. Tomcat &amp;servlet字符集编码问题
  7. day16
  8. 第一次使用eclipse出现的问题
  9. Unity3d外包—就找北京动点软件(长年承接Unity3d软件、游戏项目外包)
  10. Win10外包公司(长年承接Win10App外包、Win10通用应用外包)