轉載自 這裡
前言 :
序列化過程簡單說就是為了保存在內存中的各種對象的狀態(也就是實例變量,不只是類別本身),並且可以把保存的對象狀態再讀出來。雖然你可以用你自己的各種各樣的方法來保存object states,但是Java給你提供一種應該比你自己好的保存對象狀態的機制,那就是序列化.
什麽情況下需要序列化 :
在沒有序列化前,每個保存在堆(Heap)中的對象都有相應的狀態(state),即實例變量(instance ariable)比如 :
當 通過下面的代碼序列化之後,MyFoo對象中的width和Height實例變量的值(37,70)都被保存到foo.ser文件中,這樣以後又可以把它 從文件中讀出來,重新在堆中創建原來的對象。當然保存時候不僅僅是保存對象的實例變量的值,JVM還要保存一些小量信息,比如類的類型等以便恢復原來的對 象.
實現序列化的步驟 : (保存到一個文件)
- Make a FileOutputStream
- Make a ObjectOutputStream
- Write the object
- Close the ObjectOutputStream
簡單範例 :
相關註意事項 :
* 序列化時,只對對象的狀態進行保存,而忽略對象的方法.
* 當一個父類實現序列化,子類自動實現序列化,不需要顯式實現Serializable接口.
* 當一個對象的實例變量引用其他對象,序列化該對象時也把引用對象進行序列化
* 並非所有的對象都可以序列化,,至於為什麽不可以,有很多原因了,比如 :
補充說明 :
* Tutorials Point : Java - Serialization
* [ Gossip in Java(2) ] 輸入輸出 : 位元串流 (ObjectInputStream、ObjectOutputStream)
前言 :
序列化過程簡單說就是為了保存在內存中的各種對象的狀態(也就是實例變量,不只是類別本身),並且可以把保存的對象狀態再讀出來。雖然你可以用你自己的各種各樣的方法來保存object states,但是Java給你提供一種應該比你自己好的保存對象狀態的機制,那就是序列化.
什麽情況下需要序列化 :
在沒有序列化前,每個保存在堆(Heap)中的對象都有相應的狀態(state),即實例變量(instance ariable)比如 :
- Foo myFoo = new Foo();
- myFoo .setWidth(37);
- myFoo.setHeight(70);
實現序列化的步驟 : (保存到一個文件)
- Make a FileOutputStream
- FileOutputStream fs = new FileOutputStream("foo.ser");
- ObjectOutputStream os = new ObjectOutputStream(fs);
- os.writeObject(myObject1);
- os.writeObject(myObject2);
- os.writeObject(myObject3);
- os.close();
- import java.io.*;
- 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();
- }
- }
- }
* 序列化時,只對對象的狀態進行保存,而忽略對象的方法.
* 當一個父類實現序列化,子類自動實現序列化,不需要顯式實現Serializable接口.
* 當一個對象的實例變量引用其他對象,序列化該對象時也把引用對象進行序列化
* 並非所有的對象都可以序列化,,至於為什麽不可以,有很多原因了,比如 :
補充說明 :
* Tutorials Point : Java - Serialization
* [ Gossip in Java(2) ] 輸入輸出 : 位元串流 (ObjectInputStream、ObjectOutputStream)
我得到java.io.NotSerializableException的錯誤ㄟ
回覆刪除Main.log.info = "CNPC.saveProject()";
try{
ArrayList projectList = Main.loadProject();
projectList.add(new Main.projectItem(
name,
path
));
FileOutputStream fos = new FileOutputStream(Main.projectListFilePath);
Main.log.log(Main.projectListFilePath);
ObjectOutputStream oos = new ObjectOutputStream(fos);
Main.log.cp("ready to save projectItem to file!");
oos.writeObject(projectList);
oos.close();
fos.close();
Main.log.cp("File closed!");
}catch(Exception e){
JOptionPane.showMessageDialog(new JFrame(), e, "Error", JOptionPane.ERROR_MESSAGE);
Main.log.log(e.toString());
}
Main.log.info = "";
可以幫幫我嗎?
Check below link:
刪除https://stackoverflow.com/questions/13895867/java-io-notserializableexception