熟悉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。

添加依赖:

        <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>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

简单使用:

private static RuntimeSchema<Person> 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

最新文章

  1. (文摘)彻底理解webservice SOAP WSDL
  2. Objective-C学习笔记类目、协议
  3. JavaScript基础--内部类(九)
  4. PCRE安装
  5. Fatal error compiling: 无效的目标发行版: 1.8 -&gt; [Help 1] (zhuan)
  6. KSImageNamed-Xcode插件在xcode 6.4/6.3或其他版本中不能使用解决方案
  7. 表达式求职JAVA(转)
  8. ECHO.js 纯javascript轻量级延迟加载
  9. 6th day
  10. Android checkBox
  11. checking for known struct flock definition... configure: error: Don&#39;t know how to define struct flock on this system, set --enable-opcache=
  12. java学习历程,一年三年五年计划
  13. 全网最详细的一个超级好用的命令行工具【Cmder】的安装之后的一些配置(图文详解)
  14. 【Tomcat】Tomcat的类加载机制
  15. HttpClient 链接管理
  16. ugui使用自带功能实现反向遮罩
  17. 【原创】rabbitmq 学习
  18. Backlog和冲刺结果以及产品Demo市场调研
  19. ClamAV学习【6】—— cli_load函数浏览
  20. BZOJ1017: [JSOI2008]魔兽地图DotR【树形DP】【玄学】

热门文章

  1. 2016/3/16 45道MySQL 查询练习题
  2. NYOJ110 剑客决斗
  3. Hibernate 之 二级缓存
  4. 【Selenium】软件测试基础(软件测试分类和工具组)firebug、firepath的安装
  5. linux下Apache默认安装路径
  6. 将json文件转换成insert语句的sql文件
  7. HDU 5903 Square Distance (贪心+DP)
  8. socket实现进程间通信(转载)
  9. bzoj 4819: [Sdoi2017]新生舞会【二分+最小费用最大流】
  10. python安装教学