Home >Java >javaTutorial >How to apply Java serialization and deserialization

How to apply Java serialization and deserialization

PHPz
PHPzforward
2023-04-29 17:37:141384browse

    Java serialization and deserialization

    Java serialization turns an objectJava Object into a binary byte sequencebyte[]

    Java deserialization is to convert a binary byte sequence byte[] into a Java object Java Object

    Serialization API

    ObjectOutputStream

    Byte output stream object, writes the object's output stream to a file (used in conjunction with FileOutputStream)

    Example:

    ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("1.txt"));
    或
    FileOutputStream fout = new FileOutputStream("1.txt");
    ObjectOutputStream out = new ObjectOutputStream(fout);

    In addition, ObjectOutputStream also provides the writeObject() method to serialize an object and send it to the output stream.

    ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("1.txt"));
    out.writeObject(new Test("Sentiment",10));        //对Test类中的构造方法进行传参

    ObjectInputStream

    Byte input stream object, deserializes the binary byte sequence in the file (combined with FileInputStream)

    Example:

    ObjectInputStream in = new ObjectInputStream(new FileInputStream("1.txt"));
    或
    FileInputStream fin = new FileInputStream("1.txt");
    ObjectInputStream oin = new ObjectInputStream(fin);

    In addition, ObjectInputStream also provides the readObject() method to take out the next object from the stream and deserialize the object. Its return value is Object, therefore, it needs to be converted into an appropriate data type.

    ObjectInputStream In = new ObjectInputStream(new FileInputStream("1.txt"));
    Test o = (Test)In.readObject();
    System.out.println(o);        //读取后输出实例理解

    Example understanding

    Test.java (If a class wants to perform serialization operations, it must implement Serializable interface inheritance)

    package Sentiment.unserialize.demo01;
    
    import java.io.Serializable;
    
    public class Test implements Serializable {
        private String name;
        private int age;
    
        public Test() {
        }
    
        public Test(String name, int age) {
            this.name = name;
            this.age = age;
        }
    
        @Override
        public String toString() {
            return "Test{" + "name='" + name + '\'' + ", age=" + age + '}';
        }
    
    }

    Serializable.java

    package Sentiment.unserialize.demo01;
    
    import java.io.*;
    
    public class Serializable {
        public static void main(String[] args) throws IOException {
            ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("1.txt"));
            out.writeObject(new Test("Sentiment",10));
            out.close();
        }
    }

    UnSerializable.java

    package Sentiment.unserialize.demo01;
    
    import java.io.FileInputStream;
    import java.io.IOException;
    import java.io.ObjectInputStream;
    
    public class UnSerializable {
        public static void main(String[] args) throws IOException, ClassNotFoundException {
            ObjectInputStream In = new ObjectInputStream(new FileInputStream("1.txt"));
            Test o = (Test)In.readObject();
            System.out.println(o);
        }
    }

    After running Serializable.java, you will get the binary bytecode file content

    How to apply Java serialization and deserialization

    At this time, you will get the binary word after running UnSerializable.java Content after section code deserialization

    How to apply Java serialization and deserialization

    serialVersionUID

    • Each serializable class will be associated with a Version number, this version number is the serialVersionUID attribute

    • The serialVersionUID attribute must be modified by the static final long modifier.

    • If the serializable class does not declare the serialVersionUID attribute, Java will calculate the default serialVersionUID value based on various information about the class during serialization. However, Oracle official documentation strongly recommends that all serializable classes Serialized classes all display the serialVersionUID value.

    Instance understanding

    Defined in Test.javaserialVersionUID The value is 1

    package Sentiment.unserialize.demo01;
    
    import java.io.Serializable;
    
    public class Test implements Serializable {
        public static final long serialVersionUID = 1L;   //定义serialVersionUID 
    
        private  String name;
        private  int age;
    
        public Test() {
        }
    
        public Test(String name, int age) {
            this.name = name;
            this.age = age;
        }
    
        @Override
        public String toString() {
            return "Test{" + "name='" + name + '\'' + ", age=" + age + '}';
        }
    
    }

    Run Serializable.java at this time for serialization operation

    After the operation is completed, define the value of serialVersionUID as 2—>public static final long serialVersionUID = 2L;, during operation UnSerializable.java will report an error

    How to apply Java serialization and deserialization

    ##Transient (transient variable)

    Transient (transient variable) is a Java keyword, which is used to mark the class Member variables should not be serialized when persisted to a byte stream; when transmitting a byte stream through a network socket stream, member variables marked with the transient keyword will not be serialized. This is a static variable modified by static and does not participate in serialization operations.

    Example understanding

    Add

    transient and ## respectively in front of the name and age variables in Test.java #static<pre class="brush:java;">package Sentiment.unserialize.demo01; import java.io.Serializable; public class Test implements Serializable { public static final long serialVersionUID = 1L; //定义serialVersionUID private transient String name; //加上transient private static int age; //加上static public Test() { } public Test(String name, int age) { this.name = name; this.age = age; } @Override public String toString() { return &quot;Test{&quot; + &quot;name=&amp;#39;&quot; + name + &amp;#39;\&amp;#39;&amp;#39; + &quot;, age=&quot; + age + &amp;#39;}&amp;#39;; } }</pre>At this time, Serializable.java and UnSerializable.java are executed, and the output result is: Sentiment—>null, 10—>0

    ##readObject() method overridingHow to apply Java serialization and deserialization

    Officially allows users to override the readObject() method in the serialized class. The overridden method will be responsible for reconstructing the current class object during deserialization. Users only need to implement the defaultReadObject() method in the overridden readObject() method to ensure that the deserialization process is executed normally.

    Instance understanding

    Implement the defaultReadObject() method call, and Override this method in the Test class, and execute the command after serialization and deserialization operations

    private void readObject(java.io.ObjectInputStream a) throws IOException, ClassNotFoundException{
        a.defaultReadObject();
        Runtime.getRuntime().exec("calc.exe");
    }

    The above is the detailed content of How to apply Java serialization and deserialization. For more information, please follow other related articles on the PHP Chinese website!

    Statement:
    This article is reproduced at:yisu.com. If there is any infringement, please contact admin@php.cn delete