今天讲的是转换流序列化这一块
对象的序列化
ObjectInputStream
ObjectOutputStream
可以通过这两个流对象直接操作已有对象并将对象进行本地持久化存储。
存储后的对象可以进行网络传输。
两个对象的特有方法:
ObjectInputStream
Object readObject():该方法抛出异常:ClassNotFountException。
ObjectOutputStream
void writeObject(Object):被写入的对象必须实现一个接口:Serializable
否则会抛出:NotSerializableException
Serializable:该接口其实就是一个没有方法的标记接口。
用于给类指定一个UID。该UID是通过类中的可序列化成员的数字签名运算出来的一个long型的值。
只要是这些成员没有变化,那么该值每次运算都一样。
该值用于判断被序列化的对象和类文件是否兼容。
如果被序列化的对象需要被不同的类版本所兼容。可以在类中自定义UID。
定义方式:staticfinal long serialVersionUID = 42L;
注意:对应静态的成员变量,不会被序列化。
对应非静态也不想被序列化的成员而言,可以通过transient关键字修饰。
通常,这两个对象成对使用。
示例:
//person.java
import java.io.Serializable;
public class Person implements Serializable{
private static String nation = "china";
private String name;
private transient String interest;
public Person(String name,String interest){
this.name= name;
this.interest= interest;
}
public static String getNation(){
returnnation;
}
public static void setNation(String nation){
Person.nation= nation;
}
public void show(){
System.out.println("国籍:"+nation +"\t"+"姓名:"+ name + "爱好:" + interest);
}
}