Java Serializable(序列化)的理解

一、序列化是幹什麼的?
簡單說就是爲了保存在內存中的各類對象的狀態(也就是實例變量,不是方法),而且能夠把保存的對象狀態再讀出來。雖然你能夠用你本身的各類各樣的方法來保存object states,可是Java給你提供一種應該比你本身好的保存對象狀態的機制,那就是序列化。

二、什麼狀況下須要序列化
a)當你想把的內存中的對象狀態保存到一個文件中或者數據庫中時候;
b)當你想用套接字在網絡上傳送對象的時候;
c)當你想經過RMI傳輸對象的時候;

三、當對一個對象實現序列化時,究竟發生了什麼?
在沒有序列化前,每一個保存在堆(Heap)中的對象都有相應的狀態(state),即實例變量(instance ariable)好比:
java 代碼
  1. Foo myFoo = new Foo();
  2. myFoo .setWidth(37);
  3. myFoo.setHeight(70);
當經過下面的代碼序列化以後,MyFoo對象中的width和Height實例變量的值(37,70)都被保存到foo.ser文件中,這樣之後又能夠把它從文件中讀出來,從新在堆中建立原來的對象。固然保存時候不單單是保存對象的實例變量的值,JVM還要保存一些小量信息,好比類的類型等以便恢復原來的對象。
java 代碼
  1. FileOutputStream fs = new FileOutputStream("foo.ser");
  2. ObjectOutputStream os = new ObjectOutputStream(fs);
  3. os.writeObject(myFoo);



四、實現序列化(保存到一個文件)的步驟
a)Make a FileOutputStream
java 代碼
FileOutputStream fs = new FileOutputStream("foo.ser");
b)Make a ObjectOutputStream
java 代碼
ObjectOutputStream os = new ObjectOutputStream(fs);
c)write the object
java 代碼
os.writeObject(myObject1);
os.writeObject(myObject2);
os.writeObject(myObject3);
d) close the ObjectOutputStream
java 代碼
os.close();

五、舉例說明
java 代碼
  1. import java.io.*;
  2. public class Box implements Serializable
  3. {
  4. private int width;
  5. private int height;
  6. public void setWidth(int width){
  7. this.width = width;
  8. }
  9. public void setHeight(int height){
  10. this.height = height;
  11. }
  12. public static void main(String[] args){
  13. Box myBox = new Box();
  14. myBox.setWidth(50);
  15. myBox.setHeight(30);
  16. try{
  17. FileOutputStream fs = new FileOutputStream("foo.ser");
  18. ObjectOutputStream os = new ObjectOutputStream(fs);
  19. os.writeObject(myBox);
  20. os.close();
  21. }catch(Exception ex){
  22. ex.printStackTrace();
  23. }
  24. }
  25. }

六、相關注意事項
a)序列化時,只對對象的狀態進行保存,而無論對象的方法;
b)當一個父類實現序列化,子類自動實現序列化,不須要顯式實現Serializable接口;
c)當一個對象的實例變量引用其餘對象,序列化該對象時也把引用對象進行序列化;
d)並不是全部的對象均可以序列化,,至於爲何不能夠,有不少緣由了,好比:
1.安全方面的緣由,好比一個對象擁有private,public等field,對於一個要傳輸的對象,好比寫到文件,或者進行rmi傳輸 等等,在序列化進行傳輸的過程當中,這個對象的private等域是不受保護的。

2. 資源分配方面的緣由,好比socket,thread類,若是能夠序列化,進行傳輸或者保存,也沒法對他們進行從新的資源分 配,並且,也是沒有必要這樣實現。 java


transient,瞬時性,沒法序列化 數據庫

相關文章
相關標籤/搜索