ホームページ  >  記事  >  Java  >  Java のシリアル化と逆シリアル化を適用する方法

Java のシリアル化と逆シリアル化を適用する方法

PHPz
PHPz転載
2023-04-29 17:37:141346ブラウズ

    Java シリアル化と逆シリアル化

    Java シリアル化は、オブジェクト Java オブジェクト をバイナリ バイト シーケンスに変換しますbyte[]

    #Java 逆シリアル化は、バイナリ バイト シーケンス

    byte[] を Java オブジェクト Java オブジェクト ##シリアル化 API

    # に変換することです。 ##ObjectOutputStream

    バイト出力ストリーム オブジェクト。オブジェクトの出力ストリームをファイルに書き込みます (FileOutputStream と組み合わせて使用​​します)

    例:

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

    さらに、ObjectOutputStream は次の機能も提供します

    writeObject()

    メソッドを使用してオブジェクトをシリアル化し、出力ストリームに送信します。

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

    バイト入力ストリーム オブジェクト。ファイル内のバイナリ バイト シーケンスを逆シリアル化します (FileInputStream と組み合わせます)

    例:

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

    さらに、 ObjectInputStream は、ストリームから次のオブジェクトを取り出し、オブジェクトを逆シリアル化するための

    readObject()

    メソッドも提供します。戻り値はObjectとなるため、適切なデータ型に変換する必要があります。

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

    Test.java (クラスがシリアル化操作を実行したい場合は、Serializable インターフェイスの継承を実装する必要があります)

    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);
        }
    }

    Serializable.java を実行すると、バイナリ バイトコード ファイルの内容が取得されます

    この時点で、バイナリUnSerializable.java 実行後のワード セクション コード逆シリアル化後のコンテンツJava のシリアル化と逆シリアル化を適用する方法

    serialVersionUIDJava のシリアル化と逆シリアル化を適用する方法

    各シリアル化可能クラスはバージョン番号に関連付けられます。このバージョン番号は、serialVersionUID 属性です。
    • SerialVersionUID 属性は、static Final Long 修飾子によって変更する必要があります。
    • シリアル化可能なクラスがserialVersionUID属性を宣言していない場合、Javaはシリアル化中にクラスに関するさまざまな情報に基づいてデフォルトのserialVersionUID値を計算します。ただし、Oracleの公式ドキュメントでは、すべてのシリアル化可能なクラスを使用することを強く推奨しています。クラス シリアル化されたクラスはすべて、serialVersionUID 値を表示します。
    • インスタンスの理解
    Test.javaで定義されています

    serialVersionUID

    値は 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 + '}';
        }
    
    }
    シリアル化操作のためにこの時点で Serializable.java を実行します。

    操作が完了したら、

    serialVersionUID

    の値を 2—>public staticfinallongserialVersionUID = 2L; として定義します。 UnSerializable.java 操作ではエラーが報告されます

    ##Transient (一時変数)

    Java のシリアル化と逆シリアル化を適用する方法Transient (一時変数) は、クラスをマークするために使用される Java キーワードです。メンバー変数は、バイト ストリームに永続化する場合はシリアル化しないでください。ネットワーク ソケット ストリームを介してバイト ストリームを送信する場合、transient キーワードでマークされたメンバー変数はシリアル化されません。これは static によって変更された静的変数であり、シリアル化操作には関与しません。

    例の理解

    Test.java の

    name

    変数と

    age

    変数の前に、transient と ## をそれぞれ追加します。 #static

    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 "Test{" + "name='" + name + '\'' + ", age=" + age + '}';
        }
    
    }
    このとき、Serializable.java と UnSerializable.java が実行され、出力結果は Sentiment—>null, 10—>0# となります。

    #readObject() メソッドのオーバーライド

    ユーザーがシリアル化されたクラスの readObject() メソッドをオーバーライドできるように正式に許可します。オーバーライドされたメソッドは、逆シリアル化中に現在のクラス オブジェクトを再構築します。ユーザーのみ逆シリアル化プロセスが正常に実行されるようにするには、オーバーライドされた readObject() メソッドにdefaultReadObject() メソッドを実装する必要があります。

    Java のシリアル化と逆シリアル化を適用する方法インスタンスの理解

    defaultReadObject() メソッド呼び出しを実装し、これをオーバーライドします。 Test クラスのメソッドを使用し、シリアル化および逆シリアル化操作の後にコマンドを実行します。

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

    以上がJava のシリアル化と逆シリアル化を適用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明:
    この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。