国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

關于Java中的序列化與反序列化

瀏覽:159日期:2023-11-14 14:50:22

問題描述

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自帶的序列化強不知道幾倍,數據越大,優勢越明顯,缺點就是操作起來略微有點麻煩

標簽: java
相關文章:
主站蜘蛛池模板: 欧美一级片在线视频 | 一级片aaaa| 欧洲女同互慰在线视频 | 理论片日韩 | 青草九九| 精品免费国产一区二区三区 | 国产成人免费高清激情视频 | 美女张开腿让男人桶爽免 | 亚洲免费在线看 | 成人18免费观看的软件 | 台湾三级香港三级在线中文 | 亚洲人成在线播放网站 | 久久久久亚洲视频 | 看国产一级片 | 男女朋友做爽爽爽免费视频网 | 亚洲在线免费视频 | 找国产毛片 | 一区二区网站在线观看 | 免费看欧美一级特黄a大片一 | www.亚洲天堂 | 波多野结衣免费观看视频 | 高清一级淫片a级中文字幕 高清一区二区 | 在线视频欧美日韩 | 玖草资源在线 | 国产精品久久久久久久久久影院 | 欧美亚洲国产人成aaa | 亚洲国产日韩女人aaaaaa毛片在线 | 九草在线播放 | 毛片在线高清免费观看 | 97精品久久久久中文字幕 | 欧美日本俄罗斯一级毛片 | 草草视频在线免费观看 | 美国一级毛片免费看成人 | 久久久久久久一线毛片 | 日本一级特黄高清ab片 | 在线亚洲一区二区 | 三级网站免费看 | 欧美大尺度xxxxx视频 | 91精品久久 | 国产欧美日韩成人 | 黄色一及毛片 |