17

ファサードのポイントがよくわかりません。

public abstract class AbstractFacade<T> {

    private Class<T> entityClass;

    public AbstractFacade(Class<T> entityClass) {
        this.entityClass = entityClass;
    }

    protected abstract EntityManager getEntityManager();

    public void create(T entity) {
        getEntityManager().persist(entity);
    }

    public void edit(T entity) {
        getEntityManager().merge(entity);
    }

    public void remove(T entity) {
        getEntityManager().remove(getEntityManager().merge(entity));
    }

    public T find(Object id) {
        return getEntityManager().find(entityClass, id);
    }

    public List<T> findAll() {
        CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
        cq.select(cq.from(entityClass));
        return getEntityManager().createQuery(cq).getResultList();
    }

    public List<T> findRange(int[] range) {
        CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
        cq.select(cq.from(entityClass));
        Query q = getEntityManager().createQuery(cq);
        q.setMaxResults(range[1] - range[0]);
        q.setFirstResult(range[0]);
        return q.getResultList();
    }

    public int count() {
        CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
        Root<T> rt = cq.from(entityClass);
        cq.select(getEntityManager().getCriteriaBuilder().count(rt));
        Query q = getEntityManager().createQuery(cq);
        return ((Long) q.getSingleResult()).intValue();
    }
}

このコードがあり、このような EJB があるとします。

@Stateless
public class WrapSpecFacade extends AbstractFacade<WrapSpec> {
    @PersistenceContext
    private EntityManager em;

    @Override
    protected EntityManager getEntityManager() {
        return em;
    }

    public WrapSpecFacade() {
        super(WrapSpec.class);
    }

}

これのポイントは何ですか?なぜこれをファサードと呼ぶのですか?私にとっては、同様の機能をグループ化する単なる抽象クラスです。ありがとう。

4

3 に答える 3

18

ファサードはデザインパターンです。パターン (ソフトウェア パターン) は、コードを編成し、特定の構造を提供するための一連の規則です。パターンを使用することで、いくつかの目標を達成できます。アプリケーションを設計する際には、デザインパターンが使用されます。

Facade パターンを使用すると、プログラマーは、オブジェクトが他のオブジェクトを使用するための単純なインターフェイスを作成できます。すべてが独自のインターフェースを実装する、非常に複雑なクラスのグループで作業することを検討してください。さて、あなたが持っている多くの機能の一部だけを公開するインターフェイスを提供したいとします。そうすることで、コードの単純さ、柔軟性、統合、疎結合を実現できます。

あなたの例では、多くのアクター間の結合を管理するためにファサードが使用されています。設計上の問題です。多くのコンポーネントが相互に作用している場合、それらが結びつくほど、それらを維持するのが難しくなります (つまり、コードの維持)。Facade を使用すると、疎結合に到達できます。これは、プログラマーが常に到達しようとするべき目標です。

次の点を考慮してください。

public class MyClass1 implements Interface1 {
   public void call1() {}
   public call call2() {}
}

public class MyClass2 implements Interface2 {
   public void call3() {}
   public void call4() {}
}

public class MyClass {
   private MyClass1 a;
   private MyClass2 b;
   //calling methods call1 call2 call3 and call4 in other methods of this class
   ...
   ...
}

インターフェイスを変更せずに、call1 または call2 で使用されるクラスにあるビジネス ロジックを変更する必要がある場合、これらすべてのクラスを変更する必要はなく、いずれかのインターフェイス メソッドで使用されるメソッド内のクラスだけを変更する必要があります。最初の 2 つのクラス。

Facade を使用すると、このメカニズムを改善できます。

申し訳ありませんが、それほど素晴らしいものではないことに気づきました。デザイン パターンはソフトウェア業界で頻繁に使用されており、大規模なプロジェクトで作業する場合に非常に役立ちます。あなたのプロジェクトはそれほど大きくないと指摘するかもしれませんが、それは本当かもしれませんが、Java EE はビジネスおよびエンタープライズレベルのアプリケーションプログラミングを支援することを目的としています。そのため、ファサード パターンがデフォルトで使用されることがあります (一部の IDE も使用します)。

于 2011-01-25T20:58:40.893 に答える
8

通常、このパターンは、インターフェイスを提示している基になるクラスの実装を非表示にするか、複雑な可能性のあるものの基になる実装を簡素化するために使用されます。

ファサードは外の世界への単純なインターフェースを提示するかもしれませんが、その内部では、他のクラスのインスタンスの作成、トランザクションの管理、ファイルや TCP/IP 接続の処理など、単純化されたインターフェースによって保護できるすべてのことを行います。

于 2011-01-25T20:34:55.023 に答える
7

あなたの特定のコンテキストでは、これは実際には Facade ではありません。そのコードに含まれているのは、基本的に DAO (データ アクセス オブジェクト) です。

DAO は DB 操作のファサードと見なすことができますが、これが主な目的ではありません。これは主に DB 内部を隠すことを目的としています。あなたの例では、基になるストレージ システムを XML ファイルまたは HBase などのキーと値のストアに切り替える場合、その「ファサード」で定義されたメソッドを引き続き使用でき、クライアント コードを変更する必要はありません。

(従来の) ファサードは、クライアントから隠す必要がある複雑なデザインを扱います。複雑な API と複雑なフローを公開する (このサービスからこれを取得し、このコンバーターに渡し、結果を取得し、これで検証してから、この他のサービスに送信する) 代わりに、それらすべてを Facade にカプセル化し、単純に簡単なメソッドをクライアントに公開します。このように、API がはるかに使いやすいという事実に加えて、クライアント コードを壊すことなく、基礎となる (複雑な) 実装を自由に変更することもできます。

于 2011-01-25T21:59:05.917 に答える