"어떤 서브시스템의 일련의 인터페이스에 대한 통합된 인터페이스 제공.
퍼사드에서 고수준 인터페이스를 정의하기 때문에 서브시스템을 더 쉽게 사용할 수 있다."
사용할 메소드가 여러 클래스에 퍼져 있는 경우
필요한 클래스들을 모두 생성자로 생성하여 필요한 메소드를 각각 호출 하는 대신,
(최소 지식 원칙 (의존하는 클래스의 갯수를 최대한 적게) 위배)
별도의 클래스(퍼사드)에 사용할 클래스들을 멤버변수로 담고,
사용하고자 하는 멤버변수의 메소드들을 한곳에 묶은 새로운 메소드를 작성한다.
예를 들어, 메일 전송 로직을 다음과 같이 구현한다고 하자.
1. 수신인의 메일주소를 확인한다.
2. 메일을 전송한다.
3. 메일 전송 결과를 이력에 남긴다.
위 기능들이 각각 다른 클래스에 존재하는 메소드라고 한다면
위 세 기능을 묶은 하나의 메소드를 작성하여, 메인시스템에선 해당 메소드(서브시스템)만 호출한다.
[ValidationService class]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
package design_pattern.fasade;
public class ValidationService {
String mailAddr = "";
public ValidationService(String addr){
this.mailAddr = addr;
}
public boolean addrChk() {
if(!mailAddr.isEmpty()) {
System.out.println("mail validation check success!");
return true;
}
return false;
}
}
|
cs |
[MailService class]
1
2
3
4
5
6
7
8
|
package design_pattern.fasade;
public class MailService {
public void mailSend() {
System.out.println("mail has been sent");
}
}
|
cs |
[HstService class]
1
2
3
4
5
6
7
8
|
package design_pattern.fasade;
public class HstService {
public void hstSave() {
System.out.println("sent mail saved");
}
}
|
cs |
[Facade.class]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
package design_pattern.fasade;
public class Facade {
private ValidationService vs;
private MailService ms;
private HstService hs;
public Facade(ValidationService vs, MailService ms, HstService hs) {
this.vs = vs;
this.ms = ms;
this.hs = hs;
}
public void facadeFunc() {
if(vs.addrChk()) {
ms.mailSend();
}
hs.hstSave();
}
}
|
cs |
주시스템에서 사용하고자 하는 서브시스템들을 멤버변수로.
멤버변수 내에서 사용할 메소드들을 따로 모은, 새로운 메소드 구현(facadeFunc())
[main]
1
2
3
4
5
6
7
8
9
10
11
12
13
|
package design_pattern.fasade;
public class Main {
public static void main(String args[]) {
Facade f = new Facade(new ValidationService("receiver@gmail.com")
, new MailService()
, new HstService());
f.facadeFunc();
}
}
|
cs |
디자인 패턴 중 가장 단순한(이해하기 쉬운..) 구조이며 가장 많이 쓰이는 패턴 중 하나
반응형
'back > Design Pattern' 카테고리의 다른 글
[Design pattern] Adaptor pattern (어댑터 패턴) 그리고 캡슐화 (0) | 2020.01.26 |
---|---|
[Design pattern] Builder pattern (빌더 패턴) : 객체를 정의하는 세가지 패턴 (0) | 2019.12.24 |
[Design pattern] Proxy pattern (프록시 패턴) (2) | 2019.12.17 |
[Design pattern] Observer Pattern (옵저버패턴) 그리고 리스너 (0) | 2019.11.21 |
[Design pattern] strategy pattern (스트래터지 패턴) (0) | 2019.06.04 |