<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Cyh的博客

    Email:kissyan4916@163.com
    posts - 26, comments - 19, trackbacks - 0, articles - 220

    序列化和反序列化對象

    Posted on 2009-05-24 22:18 啥都寫點(diǎn) 閱讀(220) 評論(0)  編輯  收藏 所屬分類: J2SE
       一個大的應(yīng)用程序需要使用很多的對象,由于虛擬機(jī)內(nèi)存有限,有時不可能將所有有用的對象都放在內(nèi)存中,因此,需要將不常用的對象暫時持久化到文件中,當(dāng)需要使用該對象時,再從文件中把對象恢復(fù)到內(nèi)存,這就是對象的序列化和反序列化。

    關(guān)鍵技術(shù):
    • 需要被序列化的對象必須實現(xiàn)java.io.Serializable接口,盡管該接口沒有定義任何方法。
    • 對象輸出流ObjectOutputStream可以將對象寫入到流中,通過文件輸出流可以構(gòu)造ObjectOutputStream對象。寫對象到文件時調(diào)用writeObject方法。
    • 對象輸入流ObjectInputSteam可以從流中讀取對象到內(nèi)存,通過文件輸入流可以構(gòu)造ObjectInputStream對象。從文件讀對象到內(nèi)存時調(diào)用readObject方法,返回一個Object對象。
    • 序列化時,transient變量和類變量(靜態(tài)變量)不會被序列化。
    • 序列化時,對象按照writeObject方法的調(diào)用順序存儲在文件中,先被序列化的對象的數(shù)據(jù)在文件的前面,后被序列化的對象的數(shù)據(jù)在文件的后面。因此,在反序列化時,先讀到得對象肯定是先被序列化的對象。
     
    package book.io;


    import java.io.FileInputStream;
    import java.io.FileOutputStream;
    import java.io.ObjectInputStream;
    import java.io.ObjectOutputStream;
    import java.io.Serializable;
    import java.util.Date;
    /**
     * 序列化和反序列化對象
     
    */
    public class SerializeObject {
        
    //    一個內(nèi)部類,用于被序列化和反序列化。
        
    //一定要實現(xiàn)Serializable才能夠被序列化和反序列化。
        static class MyClass implements Serializable{
            
    //一般的實例變量會被序列化和反序列化
            private int a,b;
            
    //transient實例變量 不會 被序列化和反序列化
            private transient int c; 
            
    // 類變量 不會 被序列化和反序列化
            private static int d;
            
    public MyClass(){
            }
            
    public MyClass(int a, int b, int c, int d){
                
    this.a = a;
                
    this.b = b;
                
    this.c = c;
                MyClass.d 
    = d;
            }
            
    public String toString(){
                
    return this.a + "  " + this.b + "  " + this.c + "  " + MyClass.d;
            }
        }

        
    /**
         * 序列化對象到文件
         
    */
        
    public static void serialize(String fileName) throws Exception{
            
    //創(chuàng)建一個對象輸出流,將對象輸出到文件
            ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(fileName));
            
    //序列化一個字符串對象到文件
            out.writeObject("Today:");
            
    //序列化當(dāng)前日期對象到文件
            out.writeObject(new Date());
            
    //序列化一個MyClass對象
            MyClass my1 = new MyClass(5678);
            out.writeObject(my1);
            out.close();
        }
        
    /**
         * 從文件反序列化到對象
         
    */
        
    public static void deserialize(String fileName) throws Exception{
            
    //創(chuàng)建一個對象輸入流,從文件讀取對象
            ObjectInputStream in = new ObjectInputStream(new FileInputStream(fileName));
            
    //注意讀對象時必須按照序列化對象時的順序讀,否則會出錯
            
    //讀取字符串對象
            String today = (String)(in.readObject());
            System.out.println(today);
            
    //讀日期對象
            Date date = (Date)(in.readObject());
            System.out.println(date.toString());
            
    //讀MyClass對象,并調(diào)用它的add方法。
            MyClass my1 = (MyClass)(in.readObject());
            System.out.println(my1.toString());
            in.close();
            
    //當(dāng)恢復(fù)對象的時候,對象中的所有域被自動的恢復(fù)。如果不希望某個域被序列化,可以在它前面
            
    //加上transient關(guān)鍵字,例如下面的代碼:transient int noSer = 0;
            
    //類似的,如果類中的某個域為靜態(tài),它不會被序列化。
        }
        
    /**
         * 
    @param args
         
    */
        
    public static void main(String[] args) throws Exception{
            String fileName 
    = "c:/temp/MyClass.ser";
            SerializeObject.serialize(fileName);
            
    //注釋掉第二行,只運(yùn)行下面一行,將會發(fā)現(xiàn)輸出不同
            SerializeObject.deserialize(fileName);
        }
    }

    運(yùn)行結(jié)果:

    Today:
    Sun Jul 30 11:49:38 CST 2006
    5   6   0   8



                                                                                                           --    學(xué)海無涯
            

    主站蜘蛛池模板: www.亚洲日本| 亚洲激情视频网站| 国产亚洲综合一区二区三区| 成年人视频在线观看免费| 亚洲一区在线视频| 黄页网站在线看免费| 一本天堂ⅴ无码亚洲道久久| 成人免费看片又大又黄| 亚洲gay片在线gv网站| 免费夜色污私人影院在线观看| 一级美国片免费看| 亚洲成av人片天堂网| 99久久99久久精品免费观看| 亚洲国产美女视频| 在线观看成人免费视频| 小说专区亚洲春色校园| 亚洲精品国产精品乱码不卞| 中文字幕永久免费| 中文字幕亚洲综合精品一区| 一个人免费观看视频www| 亚洲AV日韩AV无码污污网站| 亚洲日韩国产一区二区三区| 国产成人精品一区二区三区免费| 亚洲一卡2卡3卡4卡国产网站| 韩国日本好看电影免费看| 日亚毛片免费乱码不卡一区| 亚洲成AV人片在线观看无| 1024免费福利永久观看网站| 偷自拍亚洲视频在线观看99| 国产AV无码专区亚洲AV男同| AV大片在线无码永久免费| 精品亚洲视频在线| 亚洲国产精品国自产电影| 成人毛片免费观看视频| 国产精品hd免费观看| 亚洲成人福利网站| 亚洲精品无码久久毛片| 免费人成在线观看69式小视频| 日韩亚洲人成在线综合| 亚洲成人激情在线| 国产视频精品免费|