java中的序列化And反序列化

Java序列化与反序列化
本文详细介绍了Java中序列化的重要性,包括如何通过实现Serializable接口进行对象序列化,以及如何使用ObjectInputStream进行反序列化。同时,文章还提到了序列化过程中的一些注意事项,如成员变量的序列化需求及异常处理。
一.为什么要序列化
    java中为了使对象的信息永久保存,所以提供了序列化的方式来永久保存数据
二.怎样序列化
    1.首先,想要永久保存一个java对象,必须让这个对象的类实现Serializable接口
    2.然后使用OutputStream写入要序列化的对象 (就是将对象变为输出流字节)
    3.如果想要序列化的对象的类没有实现Serializable接口,就会出现一个NotSerializableException异常
        特别注意:
            (1).想要序列化的对象的类中的所有成员变量的属性也必须是可序列化的
            (2).如果想要序列化的对象的类中的成员变量的属性没有序列化,则要在属性上加transient关键字
    举例:假如有一个Student类想要序列化,主方法中的代码:
Student student = new Student();
    student.setId(1);
    student.setName("张三");
ObjectOutputStream os = new ObjectOutputStream(new FileOutputStream("d:\\student.obj"));
    os.writeObject(student);
    os.close();
二.反序列化
    1.作用:把java对象序列化的内容又还原成java对象
    2.使用ObjectInputStream读取字节内容,还原为java对象
    举例:把Student类反序列化 主方法中的代码:
        ObjectInputStream is = new ObjectInputStream(new FileInputStream("d:\\student.obj"));
            Student s = (Student)is.readObject();
            System.out.println(s.getId());
            System.out.println(s.getName());
三.其他
    1.序列化和反序列化除了可以写入和读取对象以外,还可以写入和读取基本类型(四类八种)
    注意:(1)写入和读取基本类型的时候,读取和写入的顺序必须保持一致,如果不一致,会出现EOFException异常
         (2)如果读取时没有更多的内容了也会出现EOFException异常,所以
    建议在写入时最后一个对象使用null,这样,我们就可以判断是否读取完毕
四.序列化和反序列化是java中的一种数据传输机制
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值