java对象序列化java.io.Serializable 接口实践
java.io.Serializable 接口沒有任何方法和字段,僅僅表示實現(xiàn)它的類的對象可以被序列化。實現(xiàn)了這個接口的所有類及其子類都可以對象序列化。
序列化前,虛擬機(jī)要清楚每個對象的結(jié)構(gòu),所以序列化會比較慢,如果關(guān)心性能或者需要讀取大量的特定的類對象,可以使用 java.io.Externalizable接口 對象序列化一般出現(xiàn)在如下的環(huán)境下:
把對象的字節(jié)序列保存在物理存儲介質(zhì)中(如硬盤文件);
把對象的字節(jié)序列經(jīng)網(wǎng)絡(luò)傳輸給請求者; 序列過程的特殊處理:
private void writeObject(java.io.ObjectOutputStream out)???? throws IOException private void readObject(java.io.ObjectInputStream in)??throws IOException, ClassNotFoundException;
當(dāng)ObjectOutputStream對一個對象開始序列化/反序列化時,如果該對象類具有了方法writeObject()/readObject(),就執(zhí)行該方法,否則執(zhí)行默認(rèn)方法defaultWriteObject()/defaultReadObject().
ANY-ACCESS-MODIFIER Object writeReplace() throws ObjectStreamException;ANY-ACCESS-MODIFIER Object readResolve() throws ObjectStreamException;
在做序列化前,用另一個可序列化對象替代該序列化對象,然后進(jìn)行序列化(調(diào)用defaultWriteObject()或者
writeObject())方法完成序列化操作。 不序列化的狀態(tài):
對對象的靜態(tài)的或瞬時的(transient)成員,不會進(jìn)行序列化。 serialVersionUID 版本號:
序列化serialVersionUID 的版本號在反序列化時,用于標(biāo)志序列化的發(fā)送者和接受者是否為該對象加載了與序列化是相兼容的類,如果不兼容(serialVersionUID 不相同),會導(dǎo)致InvalidClassException 。如果類沒有顯示的聲明serialVersionUID,序列化是會計算默認(rèn)的值。默認(rèn)值在不同編譯器中的結(jié)果肯能不同,為了能更好的跨平臺,最好顯示的聲明它。
ANY-ACCESS-MODIFIER static final long serialVersionUID = 42L; 實例練習(xí):
Java代碼
- public class SerialTest {??
- ??????
- ????public static void main(String[] args){??
- ????????Customers customer = new Customers();??
- ????????try {??
- ????????????FileOutputStream file = new FileOutputStream("customer.obj");??
- ????????????ObjectOutputStream out = new ObjectOutputStream(file);??
- ????????????out.writeObject(customer);??
- ??????????????
- ????????????System.out.println(file.getFD().toString());??
- ????????????file.close();??
- ????????????out.close();??
- ??????????????
- ????????????FileInputStream fileIN = new FileInputStream("customer.obj");??
- ????????????ObjectInputStream in = new ObjectInputStream(fileIN);??
- ????????????try {??
- ????????????????Customers cus = (Customers)in.readObject();??
- /*這里雖然可以打印出靜態(tài)變量,但不是因為對它進(jìn)行了序列化,而是因為靜態(tài)變量自身的特性造成的*/??
- ????????????????System.out.println(cus.toString());??
- ????????????} catch (ClassNotFoundException e) {??
- ????????????????e.printStackTrace();??
- ????????????}??
- ????????} catch (FileNotFoundException e) {??
- ????????????e.printStackTrace();??
- ????????} catch (IOException e) {??
- ????????????e.printStackTrace();??
- ????????}??
- ????}??
- }??
- ??
- class Customers implements Serializable{??
- ????private static final long serialVersionUID = 167L;??
- ??????
- ????private String name = "aq";??
- ????private int old = 45;??
- ????private String address = "SuZhou JiangSu China";??
- ????private transient String alias = "aaq";??
- ????private static String alisa1 = "aaaq";??
- ??????
- ????private void writeObject(ObjectOutputStream out)throws IOException{????????
- ????????this.old = 55;??
- ????????out.defaultWriteObject();??
- ????}??
- ??????
- ????private void readObject(java.io.ObjectInputStream in)throws IOException, ClassNotFoundException{??
- ????????in.defaultReadObject();??
- ????????this.old = this.old + 5;??????????
- ????}??
- ??????
- ????public String toString(){??
- ????????StringBuilder builder = new StringBuilder(128);??
- ????????builder.append("\r\\r\\r\\r\nalisa1=").append(alisa1);??
- ????????return builder.toString();??
- ????}
- }
總結(jié)
以上是生活随笔為你收集整理的java对象序列化java.io.Serializable 接口实践的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 什么是治愈系甜点的制作方法?
- 下一篇: 关于对象的序列化