• io流--序列化流与反序列化流


    实现序列化必须实现Serializable接口

     

    用于从流中读取对象的

    操作流 ObjectInputStream   称为 反序列化流

    用于向流中写入对象的操作流 ObjectOutputStream   称为 序列化流

                         特点:用于操作对象。可以将对象写入到文件中,也可以从文件中读取对象。

     ObjectOutputStream 将 Java 对象的基本数据类型和图形写入 OutputStream。可以使用 ObjectInputStream 读取(重构)对象。通过在流中使用文件可以实现对象的持久存储。

                     默认产生序列号,前提实现Serializable接口             

                        不定死序列号,改变内容,反序列化就会出现报错

                       /定死序列号,改变内容,反序列化不会报错

     

                                 建立person类

    当一个对象要能被序列化,这个对象所属的类必须实现Serializable接口。否则会发生异常NotSerializableException异常。

    同时当反序列化对象时,如果对象所属的class文件在序列化之后进行的修改,那么进行反序列化也会发生异常InvalidClassException。发生这个异常的原因如下:

    l  该类的序列版本号与从流中读取的类描述符的版本号不匹配

    l  该类包含未知数据类型

    l  该类没有可访问的无参数构造方法

    Serializable标记接口。该接口给需要序列化的类,提供了一个序列版本号。serialVersionUID. 该版本号的目的在于验证序列化的对象和对应类是否版本匹配。

     

    package com.oracle.demo02;
    import java.io.Serializable;
    
    
    public class person implements Serializable {
    
       private transient String  name;     // transient  专属 不能被序列化(本身就是这个功能)
    
       public  int age;                    //static 修饰的不能被序列化(恰巧有这功能)
    
       //默认产生序列号,前提实现Serializable接口
    
       //不定死序列号,改变内容,反序列化就会出现报错
    
       //定死序列号,改变内容,反序列化不会报错
    
       private static final long  serialVersionUID=1000l;//接口给需要序列化的类,提供了一个序列版本号。
    serialVersionUID. 该版本号的目的在于验证序列化的对象和对应类是否版本匹配。
    public person(String name, int age) { super(); this.name = name; this.age = age; } public person() { super(); // TODO Auto-generated constructor stub } @Override public String toString() { return "person [name=" + name + ", age=" + age + "]"; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }

    序列化流(把类写进系统文件中)

    package com.oracle.demo02;
    
     
    
    import java.io.FileNotFoundException;
    
    import java.io.FileOutputStream;
    
    import java.io.IOException;
    
    import java.io.ObjectOutputStream;
    
     
    
    public class Demo01 {
    
     
    
             public static void main(String[] args) throws IOException {
    
                       // 序列化流
    
    1. 创建是对象
    
                       //明确目的地(写入地址)
    
                      FileOutputStream  fos=new FileOutputStream("D:\demo0611\person.txt");
    
                       //创建序列化流
    
                       ObjectOutputStream  oos=new ObjectOutputStream(fos);
    
                       //向文件中写入对象这里的序列化流要借助字节输出fos才能输出序列化对象调用。writeObject ()方法将列写进文件中
    
                       oos.writeObject(new person("张三",18));
    
                       //释放资源
    
                       oos.close();
    
                       //序列化后内容看不懂是一堆乱码,相当于加密,需要反序列化
    
            
    
     
    
             }
    
     
    
    }

    对象反序列化流ObjectInputStream

    ObjectInputStream 对以前使用 ObjectOutputStream 写入的基本数据和对象进行反序列化。支持 java.io.Serializable接口的对象才能从流读取。

    package com.oracle.demo02;
    
     
    
    import java.io.FileInputStream;
    
    import java.io.FileNotFoundException;
    
    import java.io.IOException;
    
    import java.io.ObjectInputStream;
    
     
    
    public class demo02 {
    
     
    
             public static void main(String[] args) throws IOException, ClassNotFoundException {
    
                       //反序列化流
    
                       //明确数据源
    
                       FileInputStream  fis=new FileInputStream("D:\demo0611\person.txt");
    
                       //创建反序列化流
    
                       ObjectInputStream  ois =new ObjectInputStream(fis);
    
                       Object obj=ois.readObject();
    
             //因为返回值是Objec祖宗类 所有是个多态需要向下转型,才能调用perso类的变量和方法   1.先判断
    
                       if(obj instanceof person){
    
                                person  p=(person)obj;
    
                                System.out.println(p);
    
                       }
    
                       //释放资源
    
                       fis.close();
    
             }
    
     
    
    }

    瞬态关键字transient

    当一个类的对象需要被序列化时,某些属性不需要被序列化,这时不需要序列化的属性可以使用关键字transient修饰。只要被transient修饰了,序列化时这个属性就不会序列化了。

    同时静态修饰也不会被序列化,因为序列化是把对象数据进行持久化存储,而静态的属于类加载时的数据,不会被序列化。

     

  • 相关阅读:
    Java字符串跟ASCII码互转
    java 一款可以与ssm框架完美整合的web报表控件
    使用<c:set>标签配置项目路径
    Linux下部署tomcat及tomcat war包应用程序
    支付宝app支付服务端流程
    文本数据增量导入到mysql
    java 读取mysql中数据 并取出
    实现读取文本数据,在将数据导入mysql
    给一个整形数组,给出一个值,当这个值是数组某些数字的和,求出数组下标的值
    文本数据和mysql 里面的数据比较
  • 原文地址:https://www.cnblogs.com/layuechuquwan/p/11458724.html
Copyright © 2020-2023  润新知