1、序列化是幹什麼的?
簡單說就是為了儲存在記憶體中的各種物件的狀態,並且可以把儲存的物件狀態再讀出來。雖然你可以用你自己的各種各樣的方法來儲存Object States,但是Java給你提供一種應該比你自己好的儲存物件狀態的機制,那就是序列化。
2、什麼情況下需要序列化
a)當你想把的記憶體中的物件儲存到一個檔案中或者資料庫中時候;
b)當你想用套接字在網路上傳送物件的時候;
c)當你想透過RMI傳輸物件的時候;
3、當對一個物件實現序列化時,究竟發生了什麼?
在沒有序列化前,每個儲存在堆(Heap)中的物件都有相應的狀態(state),即例項變數(instance ariable)比如:
Foo myFoo = new Foo();
myFoo .setWidth(37);
myFoo.setHeight(70);
當透過下面的程式碼序列化之後,MyFoo物件中的width和Height例項變數的值(37,70)都被儲存到
foo.ser
FileOutputStream fs = new FileOutputStream("foo.ser");
ObjectOutputStream os = new ObjectOutputStream(fs);
os.writeObject(myFoo);
4、實現序列化(儲存到一個檔案)的步驟
a)Make a FileOutputStream
java 程式碼
b)Make a ObjectOutputStream
c)write the object
os.writeObject(myObject1);
os.writeObject(myObject2);
os.writeObject(myObject3);
d) close the ObjectOutputStream
os.close();
5、舉例說明
import .*;
public class Box implements Serializable
{
private int width;
private int height;
public void setWidth(int width){
this.width
}
public void setHeight(int height){
this.height
public static void main(String[] args){
Box myBox = new Box();
myBox.setWidth(50);
myBox.setHeight(30);
try{
os.writeObject(myBox);
}catch(Exception ex){
ex.printStackTrace();
6、相關注意事項
a)當一個父類實現序列化,子類自動實現序列化,不需要顯式實現;
b)當一個物件的例項變數引用其他物件,序列化該物件時也把引用物件進行序列化;
c)並非所有的物件都可以序列化,,至於為什麼不可以,有很多原因了,比如:
1.安全方面的原因,比如一個物件擁有private,public等field,對於一個要傳輸的物件,比如寫到檔案,或者進行rmi傳輸 等等,在序列化進行傳輸的過程中,這個物件的private等域是不受保護的。
2. 資源分配方面的原因,比如socket,thread類,如果可以序列化,進行傳輸或者儲存,也無法對他們進行重新的資源分 配,而且,也是沒有必要這樣實現。
1、序列化是幹什麼的?
簡單說就是為了儲存在記憶體中的各種物件的狀態,並且可以把儲存的物件狀態再讀出來。雖然你可以用你自己的各種各樣的方法來儲存Object States,但是Java給你提供一種應該比你自己好的儲存物件狀態的機制,那就是序列化。
2、什麼情況下需要序列化
a)當你想把的記憶體中的物件儲存到一個檔案中或者資料庫中時候;
b)當你想用套接字在網路上傳送物件的時候;
c)當你想透過RMI傳輸物件的時候;
3、當對一個物件實現序列化時,究竟發生了什麼?
在沒有序列化前,每個儲存在堆(Heap)中的物件都有相應的狀態(state),即例項變數(instance ariable)比如:
Foo myFoo = new Foo();
myFoo .setWidth(37);
myFoo.setHeight(70);
當透過下面的程式碼序列化之後,MyFoo物件中的width和Height例項變數的值(37,70)都被儲存到
foo.ser
檔案中,這樣以後又可以把它 從檔案中讀出來,重新在堆中建立原來的物件。當然儲存時候不僅僅是儲存物件的例項變數的值,JVM還要儲存一些小量資訊,比如類的型別等以便恢復原來的對 象。FileOutputStream fs = new FileOutputStream("foo.ser");
ObjectOutputStream os = new ObjectOutputStream(fs);
os.writeObject(myFoo);
4、實現序列化(儲存到一個檔案)的步驟
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();
5、舉例說明
java 程式碼
import .*;
public class Box implements Serializable
{
private int width;
private int height;
public void setWidth(int width){
this.width
= width;}
public void setHeight(int height){
this.height
= height;}
public static void main(String[] args){
Box myBox = new Box();
myBox.setWidth(50);
myBox.setHeight(30);
try{
FileOutputStream fs = new FileOutputStream("foo.ser");
ObjectOutputStream os = new ObjectOutputStream(fs);
os.writeObject(myBox);
os.close();
}catch(Exception ex){
ex.printStackTrace();
}
}
}
6、相關注意事項
a)當一個父類實現序列化,子類自動實現序列化,不需要顯式實現;
b)當一個物件的例項變數引用其他物件,序列化該物件時也把引用物件進行序列化;
c)並非所有的物件都可以序列化,,至於為什麼不可以,有很多原因了,比如:
1.安全方面的原因,比如一個物件擁有private,public等field,對於一個要傳輸的物件,比如寫到檔案,或者進行rmi傳輸 等等,在序列化進行傳輸的過程中,這個物件的private等域是不受保護的。
2. 資源分配方面的原因,比如socket,thread類,如果可以序列化,進行傳輸或者儲存,也無法對他們進行重新的資源分 配,而且,也是沒有必要這樣實現。