1 对象序列化的定义:将对象的状态转换成字节流,以后可以通过这些值再生成相同状态的对象。这个过程也可以通过网络实现,可以先在Windows机器上创建一个对象,对其序列化,然后通过网络发给一台Unix机器,然后在那里准确无误地重新"装配"。像RMI、Socket、JMS、EJB它们中的一种,彼此为什么能够传递Java对象,当然都是对象序列化机制的功劳。
2 实现序列化的类必须实现Serializable接口。序列化时,类的所有数据成员应可序列化除了声明为transient或static的成员.
3 能够将对象转化为流的类:ObjectOutputStream和ObjectInputStream两个类。
ObjectInputStream(InputStream in)
ObjectOutputStream(OutputStream out)
4 例子
利用类中的readObject()和 writeObject()方法可以读/写对象流。
例1:①编写一个Person类,创建一个Person类的对象,将对象序列化。②然后保存到文件中。③之后再反序列化输出结果进行查看。④要求:name序列化,age和 address不序列化,要求分别使用transient 和static关键字。
//编写一个Person类,创建一个Person类的对象,将对象序列化,然后保存到文件中
import java.io.*;
class Person implements Serializable
{
private String name ;
transient private int age ;
public static String address;
public Person(String name, int age)
{
this.name = name ;
this.age = age ;
}
//覆写toString()方法
public String toString()
{
return "姓名 =" + this.name +", 年龄 =" + this.age +",住址="+address;
}
}
public class ooDemo15
{
public static void main(String[] args) throws FileNotFoundException, IOException, ClassNotFoundException
{
//1.先序列化
Person per = new Person("gzg",26);
per.address = "西门";
ser(per);
//2.反序列化
//System.out.println(dser());
}
//建立一个对象序列化的方法
public static void ser(Person per) throws FileNotFoundException, IOException
{
ObjectOutputStream oos = null;
//序列化时,保存的文件的后缀名随便取,不是关键
oos = new ObjectOutputStream(new FileOutputStream(new File("E://gzg4.txt")));
oos.writeObject(per);
oos.close();
}
//建立一个反序列化的方法
public static Person dser() throws FileNotFoundException, IOException, ClassNotFoundException
{
ObjectInputStream ois = null;
ois = new ObjectInputStream(new FileInputStream(new File("E://gzg4.txt")));
Object obj = null;
obj = ois.readObject();
return (Person)obj;
}
}
http://blog.csdn.net/cdguogang/archive/2009/08/20/4467255.aspx
5 修改Person后,添加瞬态对象属性字段 Thread,
class Person implements Serializable
{
private String name ;
transient private int age ;
public static String address;
private Thread t = new Thread() {
public void run() {
;
}
};
public Person(String name, int age)
{
this.name = name ;
this.age = age ;
}
//覆写toString()方法
public String toString()
{
return "姓名 =" + this.name +", 年龄 =" + this.age +",住址="+address;
}
}
抛出异常Exception in thread "main" java.io.NotSerializableException: arkblue.obj.serialdeserial.test.Person$1
6 6、相关注意事项
a)序列化时,只对对象的状态进行保存,而不管对象的方法;
b)当一个父类实现序列化,子类自动实现序列化,不需要显式实现Serializable接口;
c)当一个对象的实例变量引用其他对象,序列化该对象时也把引用对象进行序列化;
d)并非所有的对象都可以序列化,,至于为什么不可以,有很多原因了,比如:
1.安全方面的原因,比如一个对象拥有private,public等field,对于一个要传输的对象,比如写到文件,或者进行rmi传输 等等,在序列化进行传输的过程中,这个对象的private等域是不受保护的。
2. 资源分配方面的原因,比如socket,thread类,如果可以序列化,进行传输或者保存,也无法对他们进行重新的资源分 配,而且,也是没有必要这样实现。
详细出处参考:http://www.itqun.net/content-detail/206894_3.html