Java对象序列化和反序列化

当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,即Java对象序列号,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象,即反序列化。

把Java对象转换为字节序列的过程称为对象的序列化

把字节序列恢复为Java对象的过程称为对象的反序列化

对象的序列化主要有两种用途:

1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;

2) 在网络上传送对象的字节序列。

一. JDK类库中的序列化API

java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。

java.io.ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回。、

只有实现了Serializable和Externalizable接口的类的对象才能被序列化。Externalizable接口继承自Serializable接口,实现Externalizable接口的类完全由自身来控制序列化的行为,而仅实现Serializable接口的类可以采用默认的序列化方式 。

对象序列化包括如下步骤:

1) 创建一个对象输出流,它可以包装一个其他类型的目标输出流,如文件输出流;

2) 通过对象输出流的writeObject()方法写对象。

对象反序列化的步骤如下

1) 创建一个对象输入流,它可以包装一个其他类型的源输入流,如文件输入流;

2) 通过对象输入流的readObject()方法读取对象。

下面让我们来看一个对应的例子,类的内容如下:

package com.cn;

import java.io.Serializable;

public class Person implements Serializable  {

 private static final long serialVersionUID = 1L;
 
 public Person() {
  
 }
 
 public Person(String username,String password,String sex,int age) {
  this.setUsername(username);
  this.setPassword(password);
  this.setSex(sex);
  this.setAge(age);
 }
 
 private String username ;
 private String password ;
 private String sex ;
 private int age ;
 public int getAge() {
  return age;
 }
 public void setAge(int age) {
  this.age = age;
 }
 public String getUsername() {
  return username;
 }
 public void setUsername(String username) {
  this.username = username;
 }
 public String getPassword() {
  return password;
 }
 public void setPassword(String password) {
  this.password = password;
 }
 public String getSex() {
  return sex;
 }
 public void setSex(String sex) {
  this.sex = sex;
 }
 
}

package com.cn;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.Date;

public class ObjectSaver {

 public static void main(String[] args) {

  // 对象序列化
  ObjectOutputStream oos;
  try {
   oos = new ObjectOutputStream(new FileOutputStream(
     "D://objectFile.obj"));
   Person p = new Person("磊磊", "123456", "男", 26);
   p.setUsername("李波");
   p.setPassword("63692454");
   p.setSex("男");
   p.setAge(26);
   oos.writeInt(30);
   oos.writeObject(new Date());
   oos.writeObject(p);
   oos.close();
  } catch (FileNotFoundException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  }

  // 对象反序列化
  Person p2 = null;
  try {
   ObjectInputStream ois = new ObjectInputStream(new FileInputStream(
     "D://objectFile.obj"));
   p2 = (Person) ois.readObject();
   System.out.println(p2.getUsername() + "/t" + p2.getPassword()
     + "/t" + p2.getSex() + "/t" + p2.getAge());
   System.out.println((Integer) ois.readObject());
   System.out.println((Date) ois.readObject());
   ois.close();
  } catch (Exception cx) {
   cx.printStackTrace();
  }
 }

}

注意两个地方:

第一:被序列化和被反序列化的类必须实现Serializable接口;

第二:被序列化和被反序列化的类中必须有一个无参或有参的构造函数。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值