Façade (patron de conception)

En génie logiciel, le patron de conception (ou design pattern) façade a pour but de cacher une conception et une interface complexe difficile à comprendre (cette complexité étant apparue « naturellement » avec l'évolution du sous-système en question).

Objectif[modifier | modifier le code]

La façade permet de simplifier cette complexité en fournissant une interface simple du sous-système. Habituellement, la façade est réalisée en réduisant les fonctionnalités de ce dernier, mais en fournissant toutes les fonctions nécessaires à la plupart des utilisateurs.

La façade encapsule la complexité des interactions entre les objets métier participant à un workflow.

Une façade peut être utilisée pour :

  • rendre une bibliothèque plus facile à utiliser, comprendre et tester;
  • rendre une bibliothèque plus lisible;
  • réduire les dépendances entre les clients de la bibliothèque et le fonctionnement interne de celle-ci, ainsi on gagne en flexibilité pour les évolutions futures du système;
  • assainir une API que l'on ne peut pas modifier si celle-ci est mal conçue, ou mieux découper ses fonctionnalités si celle-ci n'est pas assez claire.

Un adaptateur est utilisé lorsque l'on doit respecter une interface bien définie. La façade est utilisée pour simplifier l'utilisation de l'API.

Structure[modifier | modifier le code]

Façade
La façade fait abstraction des packages 1, 2 et 3 du reste de l'application.
Clients
Les objets utilisant le patron de conception Façade pour accéder aux ressources abstraites.

Exemple[modifier | modifier le code]

Java[modifier | modifier le code]

L'exemple suivant cache une API de gestion de calendrier compliquée, derrière une façade plus simple. Il affiche :

Date: 1980-08-20 20 jours après : 1980-09-09 
 import java.util.*;    // Façade   class UserfriendlyDate {      GregorianCalendar gcal;             public UserfriendlyDate(String isodate_ymd) {          String[] a = isodate_ymd.split("-");          gcal = new GregorianCalendar(Integer.parseInt(a[0]),                Integer.parseInt(a[1])-1 /* !!! */, Integer.parseInt(a[2]));      }       public void addDays(int days) {         gcal.add(Calendar.DAY_OF_MONTH, days);       }            public String toString() {         return String.format("%1$tY-%1$tm-%1$td", gcal);      }  }    // Client   class FacadePattern {      public static void main(String[] args) {            UserfriendlyDate d = new UserfriendlyDate("1980-08-20");             System.out.println("Date : "+d);             d.addDays(20);             System.out.println("20 jours après : "+d);      }  }