搜索

首页  >  问答  >  正文

关于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

PHP中文网PHP中文网2787 天前996

全部回复(1)我来回复

  • 漂亮男人

    漂亮男人2017-05-27 17:43:47

    你这个问题是因为ObjectInputStream读出的内容必须是ObjectOutputStream写入生成的。文件内容必须符合java序列化的规范要求。你自己创建的byte数组是不能用的。


    protobuf是用于结构化数据串行化的灵活、高效、自动的方法,有如XML,不过它更小、更快、也更简单。你可以定义自己的数据结构,然后使用代码生成器生成的代码来读写这个数据结构。你甚至可以在无需重新部署程序的情况下更新数据结构。

    无论是大小还是序列化和反序列化效率,基本都是前列,比JAVA自带的序列化强不知道几倍,数据越大,优势越明显,缺点就是操作起来略微有点麻烦

    回复
    0
  • 取消回复