Movatterモバイル変換


[0]ホーム

URL:


Jump to content
WikipediaThe Free Encyclopedia
Search

Facade pattern

From Wikipedia, the free encyclopedia
Software design pattern

Thefacade pattern (also spelledfaçade) is asoftware design pattern commonly used inobject-oriented programming. Analogous to afaçade in architecture, it is anobject 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 singlewrapper 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

[edit]

The Facade[1]design pattern is one of the twenty-three well-knownGoF 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?[2]

  • To make a complex subsystem easier to use, a simple interface should be provided for a set of interfaces in the subsystem.
  • The dependencies on a subsystem should be minimized.

Clients that access a complex subsystem directly refer to (depend on) many different objects having different interfaces (tight coupling), which makes the clients hard to implement, change, test, and reuse.

What solution does the Facade design pattern describe?

Define aFacade object that

  • implements a simple interface in terms of (by delegating to) the interfaces in the subsystem and
  • may perform additional functionality before/after forwarding a request.

This enables to work through aFacade object to minimize the dependencies on a subsystem.
See also the UML class and sequence diagram below.

Usage

[edit]

A Facade is used when an easier or simpler interface to an underlying object is desired.[3] Alternatively, anadapter can be used when the wrapper must respect a particular interface and must supportpolymorphic behavior. Adecorator 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

  • a simple interface is required to access a complex system,
  • a system is very complex or difficult to understand,
  • an entry point is needed to each level of layered software, or
  • the abstractions and implementations of a subsystem are tightly coupled.

Structure

[edit]

UML class and sequence diagram

[edit]
Facade Design Pattern Class Diagram
Facade Design Pattern Sequence Diagram
A sample UML class and sequence diagram for the facade design pattern

In thisUMLclass diagram, theClient class doesn't access the subsystem classes directly.Instead, theClient works through aFacade class that implements a simple interface in terms of (by delegating to) the subsystem classes (Class1,Class2, andClass3).TheClient depends only on the simpleFacade interfaceand is independent of the complex subsystem.[4]

The sequence diagram shows the run-time interactions: TheClient object works through aFacade object that delegates the request totheClass1,Class2, andClass3instances that perform the request.

UML class diagram

[edit]

Facade
The facade class abstracts Packages 1, 2, and 3 from the rest of the application.
Clients
The objects are using the facade pattern to access resources from the packages.

Example

[edit]

This is an abstract example of how a client ("you") interacts with a facade (the "computer") to a complex system (internal computer parts, like CPU and HardDrive).

C++

[edit]
structCPU{voidFreeze();voidJump(longposition);voidExecute();};structHardDrive{char*Read(longlba,intsize);};structMemory{voidLoad(longposition,char*data);};classComputerFacade{public:voidStart(){cpu_.Freeze();memory_.Load(kBootAddress,hard_drive_.Read(kBootSector,kSectorSize));cpu_.Jump(kBootAddress);cpu_.Execute();}private:CPUcpu_;Memorymemory_;HardDrivehard_drive_;};intmain(){ComputerFacadecomputer;computer.Start();}

See also

[edit]

References

[edit]
  1. ^Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides (1994).Design Patterns: Elements of Reusable Object-Oriented Software. Addison Wesley. pp. 185ff.ISBN 0-201-63361-2.{{cite book}}: CS1 maint: multiple names: authors list (link)
  2. ^"The Facade design pattern - Problem, Solution, and Applicability".w3sDesign.com. Retrieved2017-08-12.
  3. ^Freeman, Eric; Freeman, Elisabeth; Sierra, Kathy; Bates, Bert (2004). Hendrickson, Mike; Loukides, Mike (eds.).Head First Design Patterns(paperback). Vol. 1. O'Reilly. pp. 243, 252, 258, 260.ISBN 978-0-596-00712-6. Retrieved2012-07-02.
  4. ^"The Facade design pattern - Structure and Collaboration".w3sDesign.com. Retrieved2017-08-12.

External links

[edit]
Wikimedia Commons has media related toFacade pattern.


Gang of Four
patterns
Creational
Structural
Behavioral
Concurrency
patterns
Architectural
patterns
Other
patterns
Books
People
Communities
See also
Retrieved from "https://en.wikipedia.org/w/index.php?title=Facade_pattern&oldid=1271376770"
Category:
Hidden categories:

[8]ページ先頭

©2009-2025 Movatter.jp