Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 함수형패러다임
- CleanCode
- protocol
- 아이폰프로그래밍
- fp
- DesignPattern
- 개발
- 인터페이스
- interface
- SWIFT
- 객체지향프로그래밍
- OOP
- 의존성
- 고차함수
- 이름
- 클린소프트웨어
- 개발자
- IOS
- iOS프로그래밍
- 디자인패턴
- 협업
- 문법
- 클린코드
- 부스트코스
- POP
- 의도
- Swfit
- 네이밍
- Solid
- 함수형프로그래밍
Archives
- Today
- Total
밤에 쓴 코드
Design Pattern) 옵저버 패턴 본문
옵저버 패턴
한 객체가 바뀌면 그 객체에 의존하는 다수의 객체들한테 연락을 보내고, 갱신되는 방식으로 일대다 의존성을 정의한다.
시계를 예로 들어보자.
시계들은 시간이라는 큰 개념에 의존하고 있다.
시간이 바뀌면 시계들은 내부의 상태를 변경해야하는 의무가 있다.
어떻게 표현하는게 좋을까?
알려주기
시간은 계속적으로 바뀔 것이고 , 시간을 담고 있는 Time 객체는 그에 따른 변화가 있을 것이다.
Time 객체가 자기 자신이 바뀌었을 때, 모든 시계들에게 바뀌었다는 사실과 데이터를 알려주면 되겠다.
1.시간이 바뀌었을 때 시간값을 바꿔야하는 시계객체 2.날씨가 바뀌었을 때 날씨값를 바꿔야하는 기상정보어플객체 3.날짜가 바뀌었을 때 날짜값를 바뀌어야하는 달력객체 은 어떤 공통점이 있을까?
위의 3가지 객체의 공통점은
무언가 바뀌면 , 그에 따른 무언가가 변경된다'는 사실이다.
시계,달력,기상정보어플 은 유일하게 하나만 존재하는 객체가 아니다.
위의 '시간,달력,날씨'를 주제(Subject) , '시계,기상정보어플,달력'을 관찰자(Observer) 라는 단어로 바꾸어보자.
'주제가 바뀌었을 때 주제 의값을 바꿔야하는 관찰자 '가 되겠다.
위와 같이 코드를 작성해보겠다.
주제 - 데이터가 달라지면 관찰자에게 데이터를 전달해준다.
관찰자 - 주제에 의존하며 갱신시 데이터를 전달 받습니다.
Subject.java
public interface Subject { ArrayList<Observer> observers = new ArrayList<>(); void registerObserver(ObserSver o); void removeObserver(Observer o); void notifyObserver(); }
Observer.java
public interface Observer { public void update(int hour,int min , int sec); }
느슨한 결합
상호작용을 하는 객체가 서로의 대해 알지만 , 완벽히 모든 걸 알지는 못한다.
느슨한 결합이 가져오는 이점
- 인터페이스만 알고 있어서 , 두 객체의 상호작용의 최소한의 약속 만을 알 고 있다.
- 새로운 옵저버 인스턴스를 추가할 수 있다.
- 새로운 옵저버의 타입을 추가할 수 있다.
- 주제와 옵저버가 별도 부분에 대해서는 독립적으로 재사용이 가능하다.
- 변경사항에 대해서 주제와 옵저바 사이의 상호의존성을 최소화 할수 있다.
실제 인터페이스들을 구현한 구상 클래스를 명시하여 예제 테스트를 해보자
Time.java
package 디자인패턴.옵저버패턴.Subject; public class Time implements Subject { private int hour; private int min; private int sec; public Time(int hour, int min, int sec) { this.hour = hour; this.min = min; this.sec = sec; } @Override public void registerObserver(Observer o) { this.observers.add(o); } @Override public void removeObserver(Observer o) { this.observers.remove(o); } @Override public void notifyObserver() { for (Observer observer:observers){ observer.update(this.hour,this.min,this.sec); // Observer 의 인터페이스의 최소한의 동작 update 만 알고 수행 } } public void setHour(int hour) { this.hour = hour; } public void setMin(int min) { this.min = min; } public void setSec(int sec) { this.sec = sec; } }
Clock.java
package 디자인패턴.옵저버패턴.Observer; public class Clock implements Observer,Displayable{ String currentTime ; String name; boolean form24; public Clock(String currentTime, String name, boolean form24) { this.currentTime = currentTime; this.name = name; this.form24 = form24; } @Override public void update(int hour, int min, int sec) { int finalHour = form24 ? hour : hour%12; currentTime = finalHour+"시 "+min+"분 "+sec+"초"; display(); } @Override public void display() { System.out.println(name); System.out.println(currentTime); } }
UML
'Design Pattern' 카테고리의 다른 글
Design Pattern) 싱글턴 패턴 (0) | 2019.06.23 |
---|---|
Design Pattern) 데코레이터 패턴 (0) | 2019.06.07 |
Design Pattern) 팩토리 패턴 (0) | 2019.04.29 |
Design Pattern) 스트래티지 패턴 (1) | 2019.04.28 |
Design Pattern ) 디자인패턴이란? (0) | 2019.04.28 |
Comments