關(guān)于Java中的序列化與反序列化
問題描述
1.如下代碼,將文件2.log序列化后保存到2.txt
FileInputStream fin = new FileInputStream('D:2.log'); FileOutputStream out1 = new FileOutputStream(new File('D:2.txt')); // ObjectOutputStream oop1 = new ObjectOutputStream(out1); byte[] datas = new byte[1024]; int j = 0; while ((j = fin.read(datas)) > 0) {out1.write(datas);fin.read(datas); } fin.close(); out1.close();
反序列化:使用ObjectInputStream()FileInputStream fis = new FileInputStream('D:/2.txt');ObjectInputStream oin = new ObjectInputStream(fis);oin.readObject();報(bào)錯(cuò):Exception in thread 'main' java.io.StreamCorruptedException: invalid stream header: 3139322E該怎么處理?如果文件較大,讀入時(shí)加入緩存該怎么寫?望大牛賜教,xiexie
問題解答
回答1:你這個(gè)問題是因?yàn)镺bjectInputStream讀出的內(nèi)容必須是ObjectOutputStream寫入生成的。文件內(nèi)容必須符合java序列化的規(guī)范要求。你自己創(chuàng)建的byte數(shù)組是不能用的。
protobuf是用于結(jié)構(gòu)化數(shù)據(jù)串行化的靈活、高效、自動(dòng)的方法,有如XML,不過它更小、更快、也更簡(jiǎn)單。你可以定義自己的數(shù)據(jù)結(jié)構(gòu),然后使用代碼生成器生成的代碼來讀寫這個(gè)數(shù)據(jù)結(jié)構(gòu)。你甚至可以在無需重新部署程序的情況下更新數(shù)據(jù)結(jié)構(gòu)。
無論是大小還是序列化和反序列化效率,基本都是前列,比JAVA自帶的序列化強(qiáng)不知道幾倍,數(shù)據(jù)越大,優(yōu)勢(shì)越明顯,缺點(diǎn)就是操作起來略微有點(diǎn)麻煩
相關(guān)文章:
1. javascript - react+百度地圖2. html5 - iOS的webview加載出來的H5網(wǎng)頁,怎么修改html標(biāo)簽select的樣式字體?3. vue.js - vue+webpack+vue-router 部署到nginx服務(wù)器下,非根目錄,前后端怎樣配置文件?4. javascript - 為什么當(dāng)index等于5的時(shí)候,不在當(dāng)前頁面跳轉(zhuǎn)到百度?不跳轉(zhuǎn)的代碼在倒數(shù)第五行5. angular.js - 關(guān)于angular react vue 我們?cè)谑裁磳?shí)際的開發(fā)項(xiàng)目中使用?如何選擇?6. 手動(dòng)啟動(dòng)mysql服務(wù)出錯(cuò),1067錯(cuò)誤,如何解決呢?7. index.php錯(cuò)誤,求指點(diǎn)8. 這是什么情況???9. 請(qǐng)教一條mysql的sql語句寫法;10. 跟著課件一模一樣的操作使用tp6,出現(xiàn)了錯(cuò)誤
