關于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();報錯:Exception in thread 'main' java.io.StreamCorruptedException: invalid stream header: 3139322E該怎么處理?如果文件較大,讀入時加入緩存該怎么寫?望大牛賜教,xiexie
問題解答
回答1:你這個問題是因為ObjectInputStream讀出的內容必須是ObjectOutputStream寫入生成的。文件內容必須符合java序列化的規范要求。你自己創建的byte數組是不能用的。
protobuf是用于結構化數據串行化的靈活、高效、自動的方法,有如XML,不過它更小、更快、也更簡單。你可以定義自己的數據結構,然后使用代碼生成器生成的代碼來讀寫這個數據結構。你甚至可以在無需重新部署程序的情況下更新數據結構。
無論是大小還是序列化和反序列化效率,基本都是前列,比JAVA自帶的序列化強不知道幾倍,數據越大,優勢越明顯,缺點就是操作起來略微有點麻煩
相關文章:
1. docker-compose 為何找不到配置文件?2. boot2docker無法啟動3. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?4. java中返回一個對象,和輸出對像的值,意義在哪兒5. android - E/dalvikvm: Could not find class java.nio.file.Path,6. python - linux怎么在每天的凌晨2點執行一次這個log.py文件7. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點8. mysql數據庫每次查詢是一條線程嗎?9. python是怎么實現過濾 #注釋代碼的?10. 請問一下各位老鳥 我一直在學習獨孤九賤 現在是在tp5 今天發現 這個系列視頻沒有實戰
