JAVA中的序列化与反序列化

一.什么是序列化和反序列化

java 序列化是一种将对象转换为字节流的过程。

Java反序列化是指将字节流重新转换为对象。

二.为什么要进行序列化与反序列化

        网络传输的数据都必须是二进制数据,但是在Java中都是对象,是没有办法在网络中进行传输的,所以就需要对Java对象进行序列化,而且这个转换的是可逆的,否则,无法得到原来的东西。

三.怎么序列化与反序列化

一个类的对象要想序列化成功,必须满足两个条件:

该类必须实现 java.io.Serializable 接口。

该类的所有属性必须是可序列化的。如果有一个属性不是可序列化的,则该属性必须注明是短暂的。(如果你想知道一个 Java 标准类是否是可序列化的,请查看该类的文档。检验一个类的实例是否能序列化十分简单, 只需要查看该类有没有实现 java.io.Serializable接口。)

具体的实现是由:

ObjectOutputStream  ObjectlnputStream 

 其中ObjectOutputStream是用writeObject()方法来序列化对象的

        ObjectInputSteam是用readObject()方法来反序列化的

四.什么是serialVersionUID

serialVersionUID是一种序列化与反序列的化统一的协议,一般设置为1L;

private static final long serialVersionUID=1L;

比如解压缩和压缩,如果你压缩是以四个字节压缩,解压缩是以八个字节解压缩,那么系统就会报错。

五.例子

创建一个Student类


import java.io.Serializable;
public class Student implements Serializable{

	private static final long serialVersionUID=1L;
	private Integer age;
	private String name;
	private Integer userid;
	public Integer getAge() {
		return age;
	}
	public void setAge(Integer age) {
		this.age = age;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Integer getUserid() {
		return userid;
	}
	public void setUserid(Integer userid) {
		this.userid = userid;
	}	
}

 创建一个Test测试类


import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
public class Test {
	public static void main(String[] args)throws Exception{
		Student student = new Student();
		student.setAge(18);
		student.setName("张三");
		student.setUserid(123456);
//		序列化
		ObjectOutputStream objectOutputStream= new ObjectOutputStream(new FileOutputStream("1.ser"));
		objectOutputStream.writeObject(student);
		objectOutputStream.close();
//		反序列化
		ObjectInputStream objectInputSteam = new ObjectInputStream(new FileInputStream("1.ser"));
		Student p = (Student)objectInputSteam.readObject();
		System.out.println(p.getAge());
		System.out.println(p.getName());
		System.out.println(p.getUserid());
	}
}

结果:

需要注意的是,当你在属性前加关键字 transient 或 static时候,你的属性将不会被序列化和反序列化。

六.总结

Java 序列化的缺点:1:序列化码流太大2:序列化效率低

一般建议使用第三方的JSON、Hessian、ProtoBuf等效率高的方式

文章主要理解来自菜鸟教程的java序列化,如果有不妥内容,及时联系,删搞。

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Java序列化是将对象转换为字节流的过程,以便将其存储在磁盘上或通过网络传输。而反序列化则是将字节流转换回对象的过程。 下面是一个示例,演示如何序列化反序列化一个Java对象: ```java import java.io.*; public class SerializationExample { public static void main(String[] args) { // 创建一个Person对象 Person person = new Person("Alice", 30); try { // 将Person对象序列化到文件 FileOutputStream fileOut = new FileOutputStream("person.ser"); ObjectOutputStream out = new ObjectOutputStream(fileOut); out.writeObject(person); out.close(); fileOut.close(); System.out.println("Person对象已经序列化到person.ser文件"); } catch (IOException e) { e.printStackTrace(); } try { // 将Person对象从文件反序列化出来 FileInputStream fileIn = new FileInputStream("person.ser"); ObjectInputStream in = new ObjectInputStream(fileIn); Person serializedPerson = (Person) in.readObject(); in.close(); fileIn.close(); System.out.println("从person.ser文件反序列化出的Person对象:"); System.out.println("姓名:" + serializedPerson.getName()); System.out.println("年龄:" + serializedPerson.getAge()); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } } } class Person implements Serializable { private static final long serialVersionUID = 1L; private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } } ``` 运行该程序,它会将一个Person对象序列化到文件person.ser,并从该文件反序列化出Person对象,并将其打印出来。 需要注意的是,要将一个对象序列化,该对象的类必须实现java.io.Serializable接口。否则,将会抛出NotSerializableException异常。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值