Home > Java > javaTutorial > body text

How to apply Java serialization and deserialization

PHPz
Release: 2023-04-29 17:37:14
forward
1311 people have browsed it

    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);
    Copy after login

    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类中的构造方法进行传参
    Copy after login

    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);
    Copy after login

    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);        //读取后输出实例理解
    Copy after login

    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 + '}';
        }
    
    }
    Copy after login

    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();
        }
    }
    Copy after login

    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);
        }
    }
    Copy after login

    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 + '}';
        }
    
    }
    Copy after login

    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<div class="code" style="position:relative; padding:0px; margin:0px;"><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><div class="contentsignin">Copy after login</div></div>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");
    }
    Copy after login

    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!

    Related labels:
    source:yisu.com
    Statement of this Website
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
    Popular Tutorials
    More>
    Latest Downloads
    More>
    Web Effects
    Website Source Code
    Website Materials
    Front End Template
    About us Disclaimer Sitemap
    php.cn:Public welfare online PHP training,Help PHP learners grow quickly!