Javaのオブジェクトのディープコピーを達成するための二つの方法が

Javaのオブジェクトのディープコピーを達成するための二つの方法が

免責事項:この記事はブロガーオリジナル記事です、続く BY-SAのCC 4.0を 著作権契約、複製、元のソースのリンクと、この文を添付してください。
このリンク: https://blog.csdn.net/caoxiaohong1005/article/details/78704890

 

1は、クラスがCloneableインタフェースダイレクトコールクローン()メソッドを実装していない場合は、異常なCloneNotSupportedExceptionを報告します、私はすでにオブジェクトのソースコードに書きました:

 

  1.  
    *このインスタンスの複製@return。
  2.  
    * @exceptionのCloneNotSupportedExceptionオブジェクトのクラスがない場合
  3.  
    * {@code Cloneableを}インターフェースをサポートしています。サブクラス
  4.  
    *つまり{@codeクローン}メソッドをオーバーライドすることもでき
  5.  
    *インスタンスがないことを示すためにこの例外をスロー
  6.  
    *クローニングすること。
  7.  
    * @see java.lang.Cloneable
  8.  
    * /
  9.  
    ネイティブオブジェクトのクローンを()CloneNotSupportedExceptionをスロー保護。

 
  

 

 
  

 

また、ソースコードはまた、クローンオブジェクト()メソッドに書き込まれ、私が書かれている前にオブジェクトのソースコード解析である、浅いコピーです。

 
  

2、ディープコピーメソッドを実装するカスタムクラスが2種類、順次以下に示す具体的な文言があります。

2.1、カスタムクラスは、Cloneableインタフェースを実装し、クローン()メソッドをオーバーライドします。

 

 

  1.  
    / **
  2.  
    *ディープコピーとテストのシャローコピー
  3.  
    * /
  4.  
    //テストカテゴリ1
  5.  
    クラスの人は、実装のCloneableを{
  6.  
    文字列の名前。
  7.  
    int型の年齢;
  8.  
    人物(文字列名、 int型の年齢){
  9.  
    this.name =名前;
  10.  
    this.age =年齢;
  11.  
    }
  12.  
    @オーバーライド
  13.  
    パブリックオブジェクトクローン(){
  14.  
    {試します
  15.  
    リターンsuper.clone();
  16.  
    } キャッチ(CloneNotSupportedException電子){
  17.  
    リターンNULL;
  18.  
    }
  19.  
    }
  20.  
    }
  21.  
    //テストクラス2
  22.  
     
  23.  
    クラス動物は実装Cloneableをを{
  24.  
    人をホスト; //所有者
  25.  
    年齢はint; //古いです
  26.  
    動物(人の人物、 int型の年齢){
  27.  
    this.host =人。
  28.  
    this.age =年齢;
  29.  
    }
  30.  
    @オーバーライド
  31.  
    パブリックオブジェクトクローン(){
  32.  
    {試します
  33.  
    動物動物=(動物) super.clone();
  34.  
    = animal.host(人)host.clone(); //プロセス深いコピー
  35.  
    動物を返します。
  36.  
    } キャッチ(CloneNotSupportedException電子){
  37.  
    リターンNULL;
  38.  
    }
  39.  
    }
  40.  
    }
  41.  
     
  42.  
    //テスト
  43.  
    パブリッククラスメイン{
  44.  
    パブリック静的ボイドメイン(文字列[]引数){
  45.  
    人物PERSON1 = 新しい人("cxh"、26);
  46.  
    人PERSON2 =(人物)person1.clone();
  47.  
    System.out.println( "浅いコピー---------------- --------------");
  48.  
    シャローコピーをテストするための//オブジェクトのcloneメソッド
  49.  
    // Stringクラス==テストでは、メモリアドレスと一致しています
  50.  
    System.out.println( "PERSON1 PERSON2と同じメモリアドレス名:" +(person1.name == person2.name) );
  51.  
     
  52.  
     
  53.  
     
  54.  
    System.out.println( "---------------- --------------ディープコピー")。
  55.  
    //オブジェクトのcloneメソッドをオーバーライドし、深いコピーを実現
  56.  
    //または2つのオブジェクトが二つのオブジェクトかどうかを判断するために同じメモリアドレスであり、二つのメモリアドレスならば、その深いコピーで見に==を使用
  57.  
    動物animal1 = 新しい動物(新しい人物("cxh"、26)、3)。
  58.  
    動物animal2 =(動物)animal1.clone();
  59.  
    System.out.println( "animal1 animal2ホストと同じメモリアドレス:" +(animal1.host == animal2.host) )。
  60.  
    }
  61.  
    }

出力:
 
  

 

 

 

  1.  
    ---------------- --------------シャローコピー
  2.  
    PERSON1と名前のメモリアドレスが同じであるPERSON2: trueに
  3.  
    ---------------- --------------深いコピー
  4.  
    animal1とanimal2ホストメモリアドレスは同じです:
  5.  
     
  6.  
    プロセス終了 終了コード0

 

ブログの非常に詳細な説明:http://blog.csdn.net/zhangjg_blog/article/details/18369201


 
  

 

2.2、シーケンスのディープコピーの方法によって達成される:オブジェクトをコピーする最初は、メモリ内のバイトストリームに書き込まれ、その後、新しいオブジェクトが返されると同じように保存された情報から、バイトストリームを読み込むされ、その後、新しいオブジェクトそして共有元のオブジェクトは、自然の深いコピーを達成するために、任意のアドレスに存在していません。

カスタムクラスはSerializableインタフェースを実装する必要があります。

 

  1.  
    輸入java.io. *;
  2.  
     
  3.  
    / **
  4.  
    *ディープコピーとテストのシャローコピー
  5.  
    *それを完了するために、オブジェクトの直列化されたコピーを使用する方法?バイトストリームのコピーは介してメモリに実装することは比較的容易です。親オブジェクトをバイトストリームに書き込まれ、それは、バイトストリームから読み込まれます
  6.  
    *これは、新しいオブジェクトを作成し、新しいオブジェクトと親オブジェクト間の参照および共有の問題、実際のオブジェクトのディープコピーはありません。
  7.  
    * /
  8.  
    //ツール
  9.  
    クラスCloneUtil {
  10.  
    パブリック静的<Tはシリアライズ延び> Tのクローン{(TのOBJ)を
  11.  
    T cloneObj = NULL;
  12.  
    {試します
  13.  
    //書き込みバイトストリーム
  14.  
    ByteArrayOutputStreamたBAO = 新しいByteArrayOutputStream();
  15.  
    ObjectOutputStreamのOOS = 新しいObjectOutputStreamの(のBAO)。
  16.  
    oos.writeObject(OBJ)。
  17.  
    oos.close();
  18.  
     
  19.  
    //、メモリを割り当てる元のオブジェクトを作成し、新しいオブジェクトを生成します
  20.  
    BAIS = AれるByteArrayInputStream 新しい新AれるByteArrayInputStream(baos.toByteArray()); //上記出力バイトストリームを取得します。
  21.  
    ObjectInputStreamのOIS = 新しいObjectInputStreamの(BAIS)。
  22.  
     
  23.  
    //生成された新しいオブジェクトを返します。
  24.  
    cloneObj =(T)ois.readObject();
  25.  
    ois.close();
  26.  
    } キャッチ(例外e){
  27.  
    e.printStackTrace();
  28.  
    }
  29.  
    cloneObjを返します。
  30.  
    }
  31.  
    }
  32.  
     
  33.  
    //テストカテゴリ1
  34.  
    クラスの人は、実装{シリアライズ
  35.  
    文字列の名前。
  36.  
    int型の年齢;
  37.  
    人物(文字列名、 int型の年齢){
  38.  
    this.name =名前;
  39.  
    this.age =年齢;
  40.  
    }
  41.  
     
  42.  
    }
  43.  
    //テストクラス2
  44.  
     
  45.  
    クラス動物は、実装{シリアライズ
  46.  
    人をホスト; //所有者
  47.  
    年齢はint; //古いです
  48.  
    動物(人の人物、 int型の年齢){
  49.  
    this.host =人。
  50.  
    this.age =年齢;
  51.  
    }
  52.  
    }
  53.  
     
  54.  
     
  55.  
    //テスト
  56.  
    パブリッククラスメイン{
  57.  
    パブリック静的ボイドメイン(文字列[]引数){
  58.  
    System.out.println( "---------------- --------------ディープコピー")。
  59.  
    //オブジェクトのcloneメソッドをオーバーライドし、深いコピーを実現
  60.  
    //または2つのオブジェクトが二つのオブジェクトかどうかを判断するために同じメモリアドレスであり、二つのメモリアドレスならば、その深いコピーで見に==を使用
  61.  
    動物animal1 = 新しい動物(新しい人物("cxh"、26)、3)。
  62.  
    動物animal2 = CloneUtil.clone(animal1)。
  63.  
    System.out.println( "animal1 animal2ホストと同じメモリアドレス:" +(animal1.host == animal2.host) )。
  64.  
    }
  65.  
    }

出力:

 

 

  1.  
    ---------------- --------------深いコピー
  2.  
    animal1とanimal2ホストメモリアドレスは同じです:

参考ブログ: http://blog.csdn.net/chenssy/article/details/12952063

おすすめ

転載: www.cnblogs.com/think90/p/11440153.html