亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

瀏覽:156日期: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
相關文章:
主站蜘蛛池模板: 久久er精品热线免费 | 亚洲制服丝袜第一页 | 午夜一级片 | 美国黄色一级大片 | 久久黄色网 | 一二级黄色片 | 欧美乱xxxxxxxxx | 91精品国产一区二区三区左线 | 图片专区亚洲色图 | 高清不卡一区二区 | 激情爱爱网 | 日韩美一区二区 | 国产精品视频第一区二区三区 | 麻豆成人传媒一区二区 | 日韩r级在线观看 | 精品久久看 | 一级特黄国产高清毛片97看片 | 日韩无遮挡大尺度啪啪影片 | 美国a级| 亚色最新网址 | 久久精品午夜视频 | 青草草在线观看免费视频 | 边吃奶边弄进去男女视频 | 女人一级片 | 尤物在线观看视频 | 国产精品视频免费播放 | 中文字幕日韩精品中文区 | 国产精品永久免费自在线观看 | 一级做a爰片性色毛片刺激 一级做a爰片性色毛片视频图片 | 欧美草比视频 | 日韩一级欧美一级在线观看 | 中文字幕一区二区三区在线播放 | 高清大学生毛片一级 | 黄色在线免费观看视频 | 在线永久免费观看的a站视频 | 国产精品日韩欧美一区二区 | 成人毛片免费 | 国产成人mv免费视频 | 日韩免费无砖专区2020狼 | 国产成人福利美女观看视频 | 亚洲国产精品热久久2022 |