Latest web development tutorials

Javaシリアル

Javaは、バイト列は、オブジェクトに格納されたオブジェクトデータの種類についての情報を対象のデータのタイプを含む、バイトのシーケンスとして表すことができ、対象オブジェクトシリアル化メカニズムを提供します。

ファイルは、ファイルから読み出すことができ、それがデシリアライズされる、すなわち、オブジェクト情報、データオブジェクト、およびオブジェクトデータ型の種類をメモリに使用することができるシリアル化されたオブジェクトに書き込まれた後新しいオブジェクト。

全体のプロセスは完全に異なるプラットフォーム上でオブジェクトをデシリアライズすることができ、プラットフォームシリアライズされたオブジェクト上で、つまり、Java仮想マシン(JVM)は無関係です。

ObjectInputStreamおよびObjectOutputStreamのクラスの高レベルのデータストリーム、直列化、彼らは反シーケンスオブジェクトを含む方法。

ObjectOutputStreamのクラスは、データ型のさまざまなを書くために多くの書き込み方法が、特別な方法の例外が含まれています。

public final void writeObject(Object x) throws IOException

上記の方法は、オブジェクトをシリアル化し、出力ストリームに送信します。 同様のObjectInputStreamのクラスは、次のデシリアライズオブジェクトのメソッドが含まれています。

public final Object readObject() throws IOException, 
                                 ClassNotFoundException

このメソッドは、ストリームから次のオブジェクトを受け取り、オブジェクトが直列化復元されます。 その戻り値はオブジェクトであるので、あなたは適切なデータ型に変換する必要があります。

Javaの直列は、それがどのように動作するかで実証するために、私たちはSerializableインタフェースを実装して、次のEmployeeクラスを、定義した場合、前述したEmployeeクラスのチュートリアルを使用します。

public class Employee implements java.io.Serializable
{
   public String name;
   public String address;
   public transient int SSN;
   public int number;
   public void mailCheck()
   {
      System.out.println("Mailing a check to " + name
                           + " " + address);
   }
}

順にクラスオブジェクトのシリアル化は、2つの条件が満たされなければならない成功することに注意してください:

クラスはjava.io.Serializableのオブジェクトを実装しなければなりません。

そのようなすべての属性がシリアライズ可能である必要があります。 プロパティは、シリアライズ可能ではありませんがある場合は、プロパティを簡単に記載しなければなりません。

あなたはJavaの標準クラスがシリアライズ可能であるかどうかを知りたい場合は、このクラスの説明を参照してください。 クラスのインスタンスをシリアル化することが可能かどうかをテストだけのクラスでjava.io.Serializableインタフェースを実現していない参照してくださいする必要があり、非常に簡単です。


シリアライズされたオブジェクト

ObjectOutputStreamのクラスは、オブジェクトをシリアル化するために使用され、SerializeDemo次の例では、Employeeオブジェクトをインスタンス化し、オブジェクトは、ファイルにシリアライズされます。

このプログラムが実行された後、それはemployee.serという名前のファイルを作成します。 このプログラムは、何も出力されていませんが、プログラムの役割を理解するためのコードを読むことができます。

注:オブジェクトがファイルにシリアル化されるときには、標準のJava規則に従ったの.ser拡張子を提出することです。

import java.io.*;

public class SerializeDemo
{
   public static void main(String [] args)
   {
      Employee e = new Employee();
      e.name = "Reyan Ali";
      e.address = "Phokka Kuan, Ambehta Peer";
      e.SSN = 11122333;
      e.number = 101;
      try
      {
         FileOutputStream fileOut =
         new FileOutputStream("/tmp/employee.ser");
         ObjectOutputStream out = new ObjectOutputStream(fileOut);
         out.writeObject(e);
         out.close();
         fileOut.close();
         System.out.printf("Serialized data is saved in /tmp/employee.ser");
      }catch(IOException i)
      {
          i.printStackTrace();
      }
   }
}

オブジェクトをデシリアライズ

次のプログラム例DeserializeDemo Employeeオブジェクト格納されているデシリアライゼーション、/ tmpに/ employee.ser。

import java.io.*;
public class DeserializeDemo
{
   public static void main(String [] args)
   {
      Employee e = null;
      try
      {
         FileInputStream fileIn = new FileInputStream("/tmp/employee.ser");
         ObjectInputStream in = new ObjectInputStream(fileIn);
         e = (Employee) in.readObject();
         in.close();
         fileIn.close();
      }catch(IOException i)
      {
         i.printStackTrace();
         return;
      }catch(ClassNotFoundException c)
      {
         System.out.println("Employee class not found");
         c.printStackTrace();
         return;
      }
      System.out.println("Deserialized Employee...");
      System.out.println("Name: " + e.name);
      System.out.println("Address: " + e.address);
      System.out.println("SSN: " + e.SSN);
      System.out.println("Number: " + e.number);
    }
}

コンパイルし、結果は以下の通りである上記のプログラムを実行します。

Deserialized Employee...
Name: Reyan Ali
Address:Phokka Kuan, Ambehta Peer
SSN: 0
Number:101

ここでは、次の点に注意する必要があります。

try / catchブロック内のreadObject()メソッドはClassNotFoundExceptionが例外をキャッチしようとします。 JVMは、オブジェクトをデシリアライズすることができ、バイトコードのクラスを見つけることができなければなりません。 JVMが逆シリアル化プロセスオブジェクト内のクラスを見つけることができない場合は、ClassNotFoundExceptionが例外をスローします。

戻り値、のreadObject()メソッドは、従業員の参照に変換されることに注意してください。

オブジェクトがシリアライズされると、プロパティが短いため、プロパティSSNの値が111 222 333、しかし、値が出力ストリームに送信されません。 だから、SSNは、非直列化されたEmployeeオブジェクトが0である属性。