麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

zip文檔和對象流與序列化

2019-11-14 11:03:47
字體:
來源:轉載
供稿:網友

Zip文檔(通常)以壓縮格式存儲了一個或多個文件,每個ZIP文檔都有一個包含諸如文件名字和所使用的壓縮方法等信息的頭。在java中,可以使用ZipInputStream來讀入ZIP文檔。你可能需要瀏覽文檔中每個單獨的項, getNextEntry方法就可以返回一個描述這些項的ZipEntry類型的對象。 ZipInputStream的read方法被修改為在碰到當前項的結尾時返回-1(而不是碰到ZIP文件的末尾),然后你必須調用closeEntry來讀入下一項。

		ZipInputStream z = new ZipInputStream(new FileInputStream("zip"));		ZipEntry zip;		while((zip=z.getNextEntry())!=null){			//讀取內容,用Scanner或者reader			z.closeEntry();//讀取下一個		}		z.close();ZIP輸入流在讀入ZIP文件發生錯誤時,會拋出ZipException。通常這種錯誤在ZIP文件被破壞時發生。要寫出到ZIP文件,可以使用ZipOutputStream,而對于你希望放入到ZIP文件中的每一項,都應該創建一個ZipEntry對象,并將文件名傳遞給ZipEntry的構造器,它將設置其他諸如文件日期和解壓縮方法等參數。如果需要,你可以覆蓋這些設置。然后,你需要調用ZipOutputStream的putNextEntry方法來開始寫出新文件,并將文件數據發送到ZIP流中。當完成時,需要調用closeEntry。然后,你需要對所有你希望存儲的文件都重復這個過程。下面是代碼框架:
		ZipOutputStream z = new ZipOutputStream(new FileOutputStream("f://a.zip"));		ZipEntry ze = new ZipEntry("wwww.txt");//文件名		z.putNextEntry(ze);		z.write(123);		z.write(123);		z.closeEntry();//重復上面的操作來寫多個文件		z.close();JAR文件(在第I卷第10章中討論過)只是帶有另一個項的ZIP文件,這個項稱作清單。你可以使用JarInputStream和JarOutputStream類來讀寫清單項。ZIP流是一個能夠展示流的抽象化的強大之處的實例。當你讀入以壓縮格式存儲的數據時,不必操心邊請求邊解壓數據。而且ZIP格式的字節源并非必須是文件,也可以是來自網絡連接的ZIP數據。事實上,只要Applet的類加載器能夠讀入JAR文件,那么它就能夠讀入和解壓來自網絡的數據。

對象流與序列化

當你需要存儲相同類型的數據時,使用固定長度的記錄格式是一個不錯的選擇。但是,在面向對象程序中創建的對象很少全部都具有相同的類型Java語言支持一種稱為對象序列化( object serialization)的非常通用的機制,它可以將任何對象寫出到流中,并在之后將其讀回。為了保存對象數據,首先需要打開一個ObjectOutputStream對象:

ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("f://f.txt"));
oos.writeObject(new String(xxxx));
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("f://f.txt"));ois.readObject();但是,你必須對希望在對象流中存儲或恢復的所有類都進行一下修改,這些類必須實現Serializable接口。Serializable接口沒有任何方法,因此你不需要對這些做任何改動。Cloneable接口很相似。但是,為了使類可克隆,你仍舊需要覆蓋Object類中的clone方法。

你只有在寫出對象時才能用writeObject/readObject方法,對于基本類型值,你需要使用諸如writeInt/readInt或writeDouble/readDouble這樣的方法。(對象流類都實現了DataInput/DataOutput接口。)當一個對象被多個對象共享,作為它們各自狀態的一部分時。保存會有問題所以就要序列化。每個對象都是用一個序列號( serial number)保存的,這就是這種機制之所以稱為對象序列化的原因。

比如有兩個對象共用一個相同的對象,把這兩個對象保存的流中就會有問題。不能去保存和恢復相同對象的地址,因為當對象被重新加載時,它可能占據的是與原來完全不同的內存地址。所以要序列化。

1.對你遇到的每一個對象引用都關聯一個序列號。2.對于每個對象,當第一次遇到時,保存其對象數據到流中。3.如果某個對象之前已經被保存過,那么只寫出“與之前保存過的序列號為x的對象相同”。在讀回對象時,整個過程是反過來的。4.對于流中的對象,在第一次遇到其序列號時,構建它,并使用流中數據來初始化它,然后記錄這個順序號和新對象之間的關聯。5.當遇到“與之前保存過的序列號為x的對象相同”標記時,獲取與這個順序號相關聯的對象引用。使用序列化將對象集合保存到磁盤文件中,并按照它們被存儲的樣子獲取它們。序列化的另一種非常重要的應用是通過網絡將對象集合傳送到另一臺計算機上。正如在文件中保存原生的內存地址毫無意義一樣,它們對于在不同的處理器之間的通信也是毫無意義的。因為序列化用序列號代替了內存地址,所以它允許將對象集合從一臺機器傳送到另一臺機器。transient關鍵字加上就不會被序列化。除了讓序列化機制來保存和恢復對象數據,類還可以定義它自己的機制。為了做到這一點,這個類必須實現Externalizable接口。如果一個類具有名為serialVersionUID的靜態數字成員, 它就不需要再人工地計算其指紋,而只需直接使用這個值。一旦這個靜態數據成員被置于某個類的內部,那么序列化系統將可以讀入這個類的對象的不同版本。如果數據域產生了變化,對象流將盡力將流對象轉換成這個類當前的版本。對象流會將這個類當前版本的數據域與流中版本的數據域進行比較,當然,對象流只會考慮非瞬時和非靜態的數據域。如果這兩部分數據域之間名字匹配而類型不匹配,那么對象流不會嘗試將一種類型轉換成另一種類型,因為這兩個對象不兼容;如果流中的對象具有在當前版本中所沒有的數據域,那么對象流會忽略這些額外的數據;如果當前版本具有在流化對象中所沒有的數據域,那么這些新添加的域將被設置成它們的默認值(如果是對象則是null,如果是數字則為0,如果是boolean值則是false)序列化機制有一種很有趣的用法:它提供了一種克隆對象的簡便途徑,只要對應的類是可序列化的即可。其做法很簡單:直接將對象序列化到輸出流中,然后將其讀回。這樣產生的新對象是對現有對象的一個深拷貝( deep copy)。在此過程中,我們不必將對象寫出到文件中,因為可以用ByteArrayOutputStream將數據保存到字節數組中。


上一篇:python lambda用法

下一篇:C++ 輸入與輸出

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品久久久久久久久久久天堂 | 国产亚洲精品成人a | 成人在线第一页 | 亚洲成人福利网站 | 国产交换3p国产精品 | 欧美人的天堂一区二区三区 | 精品国内视频 | 精品中文字幕在线观看 | 免费国产成人高清在线看软件 | 视频一区二区中文字幕 | 欧美日韩激情 | 久久久精品精品 | 男女羞羞视频在线免费观看 | 男女做性免费网站 | 久色视频| 性猛交ⅹxxx乱巴西 在线播放中文 | 国产精品一区二区三区在线播放 | 欧美精品欧美极品欧美激情 | 国内精品国产三级国产a久久 | 成人毛片在线 | 国产成人羞羞视频在线 | 久久久久久久亚洲视频 | 日本一级黄色大片 | 欧美成人理论片乱 | 欧美成a人片在线观看久 | 一区二区三区黄色 | 136福利视频 | 91精品观看91久久久久久国产 | 国产乱xxxx| 成人免费在线网 | 国产乱淫av片免费观看 | 日本中文不卡视频 | 久久99国产精品久久99 | 免费在线观看毛片 | 91午夜视频| 国产电影精品久久 | 国产精选电影免费在线观看网站 | 免费在线观看国产精品 | 亚洲国产高清视频 | 草草视频在线播放 | 日韩中文字幕三区 |