当前位置: 移动技术网 > IT编程>开发语言>Java > 详解Java 序列化与反序列化(Serialization)

详解Java 序列化与反序列化(Serialization)

2019年07月19日  | 移动技术网IT编程  | 我要评论

一、什么是?为什么需要?

序列化(serialization)是将对象的状态信息转化为可以存储或者传输的形式的过程,反序列化则为其逆过程。

内存的易失性;传输需要;一些应用场景中需要将对象持久化下来,以便在需要的时候进行读取。

二、jdk提供的api

java.io.objectoutputstream类的 writeobject(object obj)方法

java.io.objectinputstream类的readobject()方法

对于serializable,如果没有重写 writeobject和readobject,则调用默认的方法

externalizable继承了serializable,多了2个方法:writeexternal和readexternal,用来控制需要序列化哪些字段

三、实现方法

假定一个person类,实现了serializable或externalizable接口

import java.io.serializable;

/**
 * @author: pf_xu
 * @date: 2019/3/5 12:37
 * @version 1.0
 */
public class person implements serializable {

 private int age;
 private string name;

 public person(int age, string name) {
 this.age = age;
 this.name = name;
 }

 public void setage(int age) {
 this.age = age;
 }

 public void setname(string name) {
 this.name = name;
 }

 public int getage() {
 return age;
 }

 public string getname() {
 return name;
 }

}
import java.io.externalizable;
import java.io.ioexception;
import java.io.objectinput;
import java.io.objectoutput;

/**
 * @author: pf_xu
 * @date: 2019/3/5 13:01
 * @version 1.0
 */
public class specialperson implements externalizable {

 private int age;
 private string name;

 public specialperson(){}

 public specialperson(int age, string name) {
 this.age = age;
 this.name = name;
 }

 public void setage(int age) {
 this.age = age;
 }

 public void setname(string name) {
 this.name = name;
 }

 public int getage() {
 return age;
 }

 public string getname() {
 return name;
 }

 @override
 public void writeexternal(objectoutput out) throws ioexception {
 out.writeobject(age);
 out.writeobject(name);
 }

 @override
 public void readexternal(objectinput in) throws ioexception, classnotfoundexception {
 this.age = (integer) in.readobject();
 this.name = (string)in.readobject();
 }
}
import java.io.*;

/**
 * @author: pf_xu
 * @date: 2019/3/5 12:40
 * @version 1.0
 */
public class serializabledemo {
 public static void main(string[] args) throws ioexception, classnotfoundexception {

 person person = new person(10,"simon");
 objectoutputstream oos1 = new objectoutputstream(new fileoutputstream("object1.out"));
 oos1.writeobject(person);
 objectinputstream ois1= new objectinputstream(new fileinputstream("object1.out"));
 person re_person = (person) ois1.readobject();
 system.out.println(re_person.getname()+"---"+re_person.getage());

 specialperson specialperson = new specialperson(30,"daniel");
 objectoutputstream oos2 = new objectoutputstream(new fileoutputstream("object2.out"));
 oos2.writeobject(specialperson);
 objectinputstream ois2= new objectinputstream(new fileinputstream("object2.out"));
 specialperson re_specialperson = (specialperson)ois2.readobject();
 system.out.println(re_specialperson.getname()+"---"+re_specialperson.getage());

 }
}

  四、一些细节

1.序列化id

serialversionuid  如果两个类的id不同,则不能互相序列与反序列(可应用与版本控制,不同版本的类相互兼容或者不兼容)

2.安全性

由于其标准化导致其有泄露的风险(二进制明文,可采用加密的方法)

以上所述是小编给大家介绍的java序列化和反序列化详解整合,希望对大家有所帮助

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网