Java シリアル化は、オブジェクト Java オブジェクト
をバイナリ バイト シーケンスに変換しますbyte[]
byte[] を Java オブジェクト
Java オブジェクト ##シリアル化 API
ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("1.txt")); 或 FileOutputStream fout = new FileOutputStream("1.txt"); ObjectOutputStream out = new ObjectOutputStream(fout);
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);
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 + '}'; } }
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(); } }
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); } }
この時点で、バイナリUnSerializable.java 実行後のワード セクション コード逆シリアル化後のコンテンツ
serialVersionUID
各シリアル化可能クラスはバージョン番号に関連付けられます。このバージョン番号は、serialVersionUID 属性です。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 キーワードでマークされたメンバー変数はシリアル化されません。これは static によって変更された静的変数であり、シリアル化操作には関与しません。
Test.java の
name 変数の前に、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() メソッドを実装する必要があります。インスタンスの理解
private void readObject(java.io.ObjectInputStream a) throws IOException, ClassNotFoundException{ a.defaultReadObject(); Runtime.getRuntime().exec("calc.exe"); }
以上がJava のシリアル化と逆シリアル化を適用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。