java大数据学习第十四天-----序列化与反序列化 泛型 collection集合 ArrayList

序列化与反序列化

序列化: 对象转字节值反序列化:字节值(之前序列化生成的) 转 对象

  1. 特点:

    • 需要序列化的文件必须实现Serializable接口,用来启用序列化功能

      如果本类的对象 想要被序列化输出 那么本类必须实现可序列化接口 否则会报错

      报错信息:java.io.Not SerializableException:cn.tedu.seri.Student

      Serializable 接口是一个空接口 里面一个方法也没有 作用是当做标志 标志这个类可以被序列化

    • 不需要序列化的数据可以修饰成static,原因:static资源属于类资源,不随着对象被序列化输出

    • 每一个被序列化的文件都有一个唯一的id,如果没有添加此id,编译器会自动根据类的定义信息计算产生一个

    • 在反序列化时,如果和序列化的版本号不一致,无法完成反序列化

    • 常用与服务器之间的数据传输,序列化成文件,反序列化读取数据

    • 常用使用套接字流在主机之间传递对象

    • 不需要序列化的数据也可以被修饰成transient(临时的),只在程序运行期间在内存中存在,不会被序列化持久保存

序列化:ObjectOutputStream
  1. ObjectOutputStreamJava 对象的基本数据类型写入 OutputStream,通过在流中使用文件可以实现对象的持久存储。如果流是网络套接字流,则可以在另一台主机上或另一个进程中重构对象。
    
    构造方法:
    ObjectOutputStream(OutputStream out)
    创建写入指定 OutputStreamObjectOutputStream
    普通方法:
    writeObject(Object obj)
    将指定的对象写入 ObjectOutputStream
    
    
反序列化:ObjectInputStream
  1. ObjectInputStream对以前使用ObjectOutputStream写入的基本数据和对象进行反序列化重构对象。
        
    构造方法:
    ObjectInputStream(InputStream in) 创建从指定 InputStream 读取的 ObjectInputStream
    普通方法:
    readObject()ObjectInputStream 读取对象
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值