java实现系列化的jdk_Java序列化技术性能分析(JDK原生与Protostuff)

熟悉Java的朋友应该知道Java有一个叫序列化的技术,即把一个Object转换为可保存,可传输的流数据。相应的,同时存在反序列化,即将流数据转换为Object类,而在转换的过程中,该Object保持者其自身的状态。不会应该序列化或者反序列化而丢失。通常在缓存中,RPC(远程调用),或者长久保存会话信息时,大有用处。

关于序列化的时候,大部分情况下想到的是对于需要序列化的对象实现Serializable标志接口,同时为该对象提供一个唯一的serialVersionUID。

示例代码

public class Person implements Serializable {

private static final long serialVersionUID = -763618247875550322L;

private String name;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

1

2

3

4

5

6

7

8

9

10

11

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.ObjectInputStream;

import java.io.ObjectOutputStream;

public class WhySerialversionUID {

public static void main(String[] args) throws Exception {

//这里是把对象序列化到文件

Person crab = new Person();

crab.setName("kaka");

ObjectOutputStream oo = new ObjectOutputStream (new FileOutputStream("kakaFile"));

oo.writeObject(crab);

oo.close();

//这里是把文件序列化到对象

ObjectInputStream oi = new ObjectInputStream (new FileInputStream("kakaFile"));

Person kaka = (Person) oi.readObject();

//输出为Hi, My name is kaka

System.out.println("Hi, My name is " + kaka.getName());

oi.close();

}

}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

看起来使用JDK提供的序列化技术没有什么问题,其实不然。JDK提供的序列化技术相对而已效率较低。在转换二进制数组过程中空间利用率较差。github上有个专门对比序列化技术做对比的数据:https://github.com/eishay/jvm-serializers/wiki

其中看的出来性能最优的为google开发的colfer 。这个框架尽管性能优秀,但它太过于灵活,灵活到Schema都要开发者自己指定,所以对开发者不是很友好。我推荐使用Protostuff,其性能稍弱与colfer,但对开发者很友好,同时性能远远高于JDK提供的Serializable。

添加依赖:

io.protostuff

protostuff-core

1.4.4

io.protostuff

protostuff-runtime

1.4.4

1

2

3

4

5

6

7

8

9

10

简单使用:

private static RuntimeSchema schema = RuntimeSchema.createFrom(Person.class);

/**

*序列化

*/

Person crab = new Person();

crab.setName("kaka");

//参数三缓冲器

byte[] bytes = ProtostuffIOUtil.toByteArray(crab,schema,LinkedBuffer.allocate(LinkedBuffer.DEFAULT_BUFFER_SIZE));

/**

*反序列化

*/

// 空对象

Person newCrab = schema.newMessage();

ProtostuffIOUtil.mergeFrom(bytes,newCrab,schema);

System.out.println("Hi, My name is " + newCrab.getName());

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值