Facade pattern


The facade pattern is a software-design pattern commonly used in object-oriented programming. Analogous to a facade in architecture, a facade is an object that serves as a front-facing interface masking more complex underlying or structural code. A facade can:
Developers often use the facade design pattern when a system is very complex or difficult to understand because the system has many interdependent classes or because its source code is unavailable. This pattern hides the complexities of the larger system and provides a simpler interface to the client. It typically involves a single wrapper class that contains a set of members required by the client. These members access the system on behalf of the facade client and hide the implementation details.

Overview

The Facade
design pattern is one of the twenty-three well-known
GoF design patterns
that describe how to solve recurring design problems to design flexible and reusable object-oriented software, that is, objects that are easier to implement, change, test, and reuse.
What problems can the Facade design pattern solve?
Clients that access a complex subsystem directly refer to many different objects having different interfaces, which makes the clients hard to implement, change, test, and reuse.
What solution does the Facade design pattern describe?
Define a Facade object that
This enables to work through a Facade object to minimize the dependencies on a subsystem.
See also the UML class and sequence diagram below.

Usage

A Facade is used when an easier or simpler interface to an underlying object is desired. Alternatively, an adapter can be used when the wrapper must respect a particular interface and must support polymorphic behavior. A decorator makes it possible to add or alter behavior of an interface at run-time.
PatternIntent
AdapterConverts one interface to another so that it matches what the client is expecting
DecoratorDynamically adds responsibility to the interface by wrapping the original code
FacadeProvides a simplified interface

The facade pattern is typically used when

UML class and sequence diagram

In this UML class diagram,
the Client class doesn't access the subsystem classes directly.
Instead, the Client works through a Facade class that implements a simple interface in terms of the subsystem classes.
The Client depends only on the simple Facade interface
and is independent of the complex subsystem.
The sequence diagram
shows the run-time interactions: The Client object
works through a Facade object that delegates the request to
the Class1, Class2, and Class3
instances that perform the request.

UML class diagram

; Facade
; Clients

Example

This is an abstract example of how a client interacts with a facade to a complex system.

C++


struct CPU ;
struct HardDrive ;
struct Memory ;
class ComputerFacade ;
int main