色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

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

瀏覽:163日期: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
相關文章:
主站蜘蛛池模板: 亚洲清纯自偷自拍另类专区 | 美女网站在线观看视频18 | 欧美日韩加勒比一区二区三区 | 国产成人手机视频 | 久久久婷 | 毛片观看网址 | 精品国产乱码久久久久久一区二区 | 91精品国产综合久久久久 | 欧美片欧美日韩国产综合片 | 热伊人99re久久精品最新地 | 自拍偷在线精品自拍偷无码专区 | 久久精品女人毛片国产 | 精品久久久久久国产 | 国产成人免费全部网站 | 欧美一级毛片欧美一级 | 九草视频在线 | 手机黄色网址 | 成人国产网站v片免费观看 成人国产午夜在线视频 | 欧美日韩一区二区三区在线观看 | 国产精品国产亚洲精品不卡 | 91精品欧美综合在线观看 | 亚洲欧美精品网站在线观看 | 萌白酱国产一区 | 成人三级毛片 | 最近中文字幕在线 | 中文 | 日本波多野结衣视频 | 欧美日韩综合网在线观看 | 精品久久一区二区三区 | 久久99国产亚洲高清观看首页 | 91视频天堂| 日本在线观看一级高清片 | 欧美一区二区三区视频在线 | 京东一热本色道久久爱 | 奇米888四色在线精品 | 欧美日韩中文国产一区二区三区 | 国美女福利视频午夜精品 | 77yyxf影音先锋 | 手机在线看片国产日韩生活片 | 久久99中文字幕 | 日本精品久久久久久久久免费 | 国产91精品露脸国语对白 |