デザインパターン-プロトタイプパターン

プロトタイプパターンとは、パフォーマンスを念頭に置いて重複オブジェクトを作成することです。このタイプのデザインパターンは、オブジェクトを作成するための最良の方法の1つを提供するため、作成パターンに分類されます。

このパターンには、現在のオブジェクトのクローンを作成するように指示するプロトタイプインターフェイスの実装が含まれます。このパターンは、オブジェクトを直接作成するのにコストがかかる場合に使用されます。たとえば、オブジェクトは、コストのかかるデータベース操作の後に作成されます。オブジェクトをキャッシュし、次のリクエストでそのクローンを返し、必要に応じてデータベースを更新することで、データベースの呼び出しを減らすことができます。

実装

抽象クラスShapeと、Shapeクラスを拡張する具象クラスを作成します。クラスShapeCacheは、シェイプオブジェクトをハッシュテーブルに格納し、要求されたときにそれらのクローンを返す次のステップとして定義されます。

PrototypPatternDemo、デモクラスはShapeCacheクラスを使用してShapeオブジェクトを取得します。

ステップ1

Clonableインターフェースを実装する抽象クラスを作成します。

Shape.java

public abstract class Shape implements Cloneable {
   
   private String id;
   protected String type;
   
   abstract void draw();
   
   public String getType(){
      return type;
   }
   
   public String getId() {
      return id;
   }
   
   public void setId(String id) {
      this.id = id;
   }
   
   public Object clone() {
      Object clone = null;
      
      try {
         clone = super.clone();
         
      } catch (CloneNotSupportedException e) {
         e.printStackTrace();
      }
      
      return clone;
   }
}

ステップ2

上記のクラスを拡張する具象クラスを作成します。

Rectangle.java

public class Rectangle extends Shape {

   public Rectangle(){
     type = "Rectangle";
   }

   @Override
   public void draw() {
      System.out.println("Inside Rectangle::draw() method.");
   }
}

Square.java

public class Square extends Shape {

   public Square(){
     type = "Square";
   }

   @Override
   public void draw() {
      System.out.println("Inside Square::draw() method.");
   }
}

Circle.java

public class Circle extends Shape {

   public Circle(){
     type = "Circle";
   }

   @Override
   public void draw() {
      System.out.println("Inside Circle::draw() method.");
   }
}

ステップ3

データベースから具象クラスを取得するクラスを作成し、それらをハッシュテーブルに格納します。

ShapeCache.java

import java.util.Hashtable;

public class ShapeCache {
	
   private static Hashtable<String, Shape> shapeMap  = new Hashtable<String, Shape>();

   public static Shape getShape(String shapeId) {
      Shape cachedShape = shapeMap.get(shapeId);
      return (Shape) cachedShape.clone();
   }

   // for each shape run database query and create shape
   // shapeMap.put(shapeKey, shape);
   // for example, we are adding three shapes
   
   public static void loadCache() {
      Circle circle = new Circle();
      circle.setId("1");
      shapeMap.put(circle.getId(),circle);

      Square square = new Square();
      square.setId("2");
      shapeMap.put(square.getId(),square);

      Rectangle rectangle = new Rectangle();
      rectangle.setId("3");
      shapeMap.put(rectangle.getId(), rectangle);
   }
}

ステップ4

PrototypePatternDemoは、ShapeCacheクラスを使用して、ハッシュテーブルに格納されているシェイプのクローンを取得します。

PrototypePatternDemo.java

public class PrototypePatternDemo {
   public static void main(String[] args) {
      ShapeCache.loadCache();

      Shape clonedShape = (Shape) ShapeCache.getShape("1");
      System.out.println("Shape : " + clonedShape.getType());		

      Shape clonedShape2 = (Shape) ShapeCache.getShape("2");
      System.out.println("Shape : " + clonedShape2.getType());		

      Shape clonedShape3 = (Shape) ShapeCache.getShape("3");
      System.out.println("Shape : " + clonedShape3.getType());		
   }
}

ステップ5

出力を確認します。

Shape : Circle
Shape : Square
Shape : Rectangle