关于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. javascript - 类似于天猫和京东,商品详情页上拉查看图文详情,是通过什么方式实现的?2. python - Flask云部署,gunicorn运行成功,但是通过外网端口无法访问3. css3 - 淘宝网上这种抵抗反弹的效果如何做?4. html5 - 请求到了网易云歌曲到在线地址,如何在web页面中播放?5. javascript - 微信小程序限制加载个数6. javascript - 网易云音乐是如何实现a标签href有值不跳转的?7. css3 - 新版支付宝 账单页面滑动时月份栏被下一个月给顶上去是什么效果8. html5 - 自己的H5页面如何集成支付宝支付9. nginx - WordPress绑定了域名后主页依然显示ip,以及WordPress目录问题10. linux - 为公司配置服务器,要求在上面装win7的虚拟机,那我还需要装桌面环境吗?
