1、序列化是干什么的?
简单说就是为了保存在内存中的各种对象的状态(也就是实例变量,不是方法),并且可以把保存的对象状态再读出来。虽然你可以用你自己的各种各样的方法来保存
object states,但是Java给你提供一种应该比你自己好的保存对象状态的机制,那就是序列化。
2、什么情况下需要序列化
a)当你想把的内存中的对象状态保存到一个文件中或者数据库中时候;
b)当你想用套接字在网络上传送对象的时候;
c)当你想通过RMI传输对象的时候;
3、当对一个对象实现序列化时,究竟发生了什么?
在没有序列化前,每个保存在堆(Heap)中的对象都有相应的状态(state),即实例变量(instance ariable)比如:
Student student = new Student();
student.setId(1);
student.setName("Harrison");
student.setSex("boy");
当通过下面的代码序列化之后,
Student对象中的
id,
name和
sex实例变量的值都被保存到
data.ser文件中,这样以后又可以把它从文件中读出来,重新在堆中创建原来的对象。当然保存时候不仅仅是保存对象的实例变量的值,JVM还要保存一些小量信息,比如类的类型等以便恢复原来的对象。
// Make a FileOutputStream
FileOutputStream fos = new FileOutputStream("data.ser");
// Make a ObjectOutputStream
ObjectOutputStream oos = new ObjectOutputStream(fos);
// Write the object
oos.writeObject(student);
// Close the ObjectOutputStream
oos.close();
// Close the FileOutputStream
fos.close();
4、相关注意事项
a)序列化时,只对对象的状态进行保存,而不管对象的方法;
b)当一个父类实现序列化,子类自动实现序列化,不需要显式实现Serializable接口;
c)当一个对象的实例变量引用其他对象,序列化该对象时也把引用对象进行序列化;
d)并非所有的对象都可以序列化,,至于为什么不可以,有很多原因了,比如:
1.安全方面的原因,比如一个对象拥有
private,
public等field,对于一个要传输的对象,比如写到文件,或者进行
rmi传输 等等,在序列化进行传输的过程中,这个对象的
private等域是不受保护的。
2.资源分配方面的原因,比如
socket,
thread类,如果可以序列化,进行传输或者保存,也无法对他们进行重新的资源分配,而且,也是没有必要这样实现。
5、测试代码
/*
* @(#)StudentTest.java 1.0 Jun 4, 2010
*/
package org.asheng.model;
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 org.junit.Test;
/**
* @author Harrison Wang
* @version 1.0
*/
public class StudentTest {
private ObjectOutputStream oos;
private FileOutputStream fos;
private ObjectInputStream ois;
private FileInputStream fis;
/**
* Write the object instance
* @param student
* @return
*/
public boolean writeInstance(Student instance) {
try {
// Make a FileOutputStream
fos = new FileOutputStream("data.ser");
// Make a ObjectOutputStream
oos = new ObjectOutputStream(fos);
// Write the object
oos.writeObject(instance);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
// Close the ObjectOutputStream
oos.close();
// Close the FileOutputStream
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return true;
}
/**
* Read the object instance
* @return
*/
public Student readInstance() {
Student stu = null;
try {
// Make a FileInputStream
fis = new FileInputStream("data.ser");
// Make a ObjectInputStream
ois = new ObjectInputStream(fis);
// Get the Object
stu = (Student) ois.readObject();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} finally {
try {
// Close the ObjectInputStream
ois.close();
// Close the FileInputStream
fis.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return stu;
}
@Test
public void test() {
Student student = new Student();
student.setId(1);
student.setName("Harrison");
student.setSex("boy");
boolean isWriteen = writeInstance(student);
if (isWriteen == true) {
// Get the student instance
Student stu = readInstance();
// Print the student name
System.out.println(stu.getName());
}
}
}
/*
* @(#)Student.java 1.0 Jun 4, 2010
*/
package org.asheng.model;
import java.io.Serializable;
/**
* @author Harrison Wang
* @version 1.0
*/
public class Student implements Serializable {
private static final long serialVersionUID = 1L;
private int id;
private String name;
private String sex;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
}
分享到:
相关推荐
java 的序列化与反序列化举例测试
Java_Serializable(序列化) 的理解和总结
java序列化(Serializable)的作用和反序列化.doc 有详细的讲解哦。 在什么地方用的到都有说明的.
java.io.Serializable序列化问题
序列化是干什么的? 简单说就是为了保存在内存中的各种对象的状态(也就是实例...虽然你可以用你自己的各种各样的方法来保 存object states,但是Java给你提供一种应该比你自己好的保存对象状态的机制,那就是序列化。
java 序列化 对象 Serializable 写着玩的Demo 简单 实用
Serializable序列化步骤
java序列化(Serializable)的作用和反序列化.pdf
序列化 serializable demo ! 序列化 serializable demo !
这是Java 序列化(Serializable)实现的一个例子,例子是显示文件的读写的。
通过实现 Serializable 接口,Java对象可以被序列化和反序列化。序列化可以将对象转换为字节流,以便于存储或传输。反序列化则可以将字节流重新转换为原始对象。需要注意的是,序列化和反序列化的类必须具有相同的 ...
Java序列化(Serializable)与反序列化_.docx
Java中的序列化机制有两种实现方式: 一种是实现Serializable接口 另一种是实现Externalizable接口 区别: 实现Serializable接口 1 系统自动储存必要的信息 2 Java内建支持,易于实现,只需实现该接口即可,无须任何...
Java序列化(Serializable)与反序列化__1.docx
java 序列化的问题 如何认识和解决序列化 java serializable
为什么实现了java.io.Serializable接口才能被序列化 transient的作用是什么 怎么自定义序列化策略 自定义的序列化策略是如何被调用的 ArrayList对序列化的实现有什么好处 Java对象的序列化 ...
什么叫序列化? 我们都知道对象是暂时保存在内存中的,不...在进行这些操作的时候都需要这个可以被序列化,要能被序列化,就得给类头加[Serializable]特性。 通常网络程序为了传输安全才这么做。不知道回答清晰满意否?
Serializable接口和Externalizable接口实现序列化和反序列化
比较常见的做法有两种: 一是把对象包装成JSON字符串传输, 二是采用Java对象的序列化和反序列化。 随着Google工具protoBuf的开源,protobuf也是个不错的选择。 *提示:对JSON,Object Serialize,ProtoBuf 做个对比。...
Java 中 Serializable的应用,序列化的作用说明