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 |
Tags
- 자바
- 백준 15661
- 프로그래머스 숫자의 표현 java
- java
- Arrays
- 백준 11723
- java 내림
- 프로그래머스 연속된 수의 합 java
- 프로그래머스 도둑질 java
- 네트워크
- 알고리즘
- 프로그래머스 네트워크 java
- 코딩테스트
- 백준 16935
- sort
- Math.floor()
- Algorithm
- mysql
- 백준 4375
- 0으로 채우기
- 백준 18290
- 백준 14391
- Codility
- java 반올림
- 백준 17425
- Math.ceil()
- 프로그래머스 옹알이 java
- time complexity
- 백준 16927
- java 올림
Archives
- Today
- Total
취미처럼
[DP] 어댑터 패턴 본문
어댑터 패턴(Adapter pattern)
클래스의 인터페이스를 사용자가 기대하는 다른 인터페이스로 변환하는 패턴으로, 호환성이 없는 인터페이스 때문에 함께 동작할 수 없는 클래스들이 함께 작동하도록 해준다.
어댑터 패턴을 예로 들자면 자바에서 데이터베이스를 접속할 때 사용하는 JDBC를 예를 들 수 있다. JDBC를 통해 다양한 데이터베이스를 접근할 수 있다.
/**
* Java code sample
*/
/* the client class should instantiate adapter objects */
/* by using a reference of this type */
interface Stack<T>
{
void push (T o);
T pop ();
T top ();
}
/* DoubleLinkedList is the adaptee class */
class DList<T>
{
public void insert (DNode pos, T o) { ... }
public void remove (DNode pos) { ... }
public void insertHead (T o) { ... }
public void insertTail (T o) { ... }
public T removeHead () { ... }
public T removeTail () { ... }
public T getHead () { ... }
public T getTail () { ... }
}
/* Adapt DList class to Stack interface is the adapter class */
class DListImpStack<T> extends DList<T> implements Stack<T>
{
public void push (T o) {
insertTail (o);
}
public T pop () {
return removeTail ();
}
public T top () {
return getTail ();
}
}
'Design Pattern' 카테고리의 다른 글
[DP] 데코레이터 패턴 (0) | 2021.03.19 |
---|---|
[DP] 빌더 패턴 (0) | 2021.03.19 |
[DP] 프록시 패턴 (0) | 2021.03.19 |
[DP] 옵저버 패턴 (0) | 2021.03.19 |
[DP] 전략 패턴 (0) | 2021.03.19 |
Comments