inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

데코레이터 패턴 - 예제 코드3

데코레이터 패턴에서 Component 코드 질문 있습니다

해결된 질문

172

blackhole124

작성한 질문수 60

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

아래와 같은 코드에서

MessageDecorator 클래스는 Component 인터페이스를 구현하면서

operation 메서드를 구체화한 것은 이해를 했습니다.

근데 데코레이터 패턴에서 MessageDecorator 클래스가 Component 클래스를 구현하면서

Component 클래스를 필드로 갖는 이유가 무엇인지 잘 이해가 안됩니다 설명 부탁드립니다

package springHigh.advanced.pureproxy.decorator.code;

import lombok.extern.slf4j.Slf4j;

@Slf4j
public class MessageDecorator implements Component{
    private Component component;

    public MessageDecorator(Component component) {
        this.component = component;
    }

    @Override
    public String operation() {
        log.info("MessageDecorator 실행");

        // data => *** data ****
        String result = component.operation();
        String decoResult = "******" + result+"*******";
        log.info("MessageDecorator 적용");
        return decoResult;
    }
}

 

spring 디자인-패턴

답변 2

0

y2gcoder

안녕하세요. blackhole124님, 공식 서포터즈 y2gcoder입니다.

데코레이터 패턴을 사용하는 이유는 저희가 아는 데코레이션을 한다는 의미와 같습니다 🙂

원래 대상의 겉을 더 꾸며주는 의미로 사용하는 것과 같이 데코레이터 패턴도 하나의 객체를 그대로 두고 부가적인 기능을 추가해주는 역할을 한다고 저는 이해하고 있습니다!

그러한 관점에서 보면, 먼저 Component 를 상속하는 이유는 해당 객체를 사용할 자리에 데코레이트 한 기능 구현체를 대신 주입함으로써 편리하게 부가 기능을 추가할 수 있습니다. 해당 기능을 사용하기 싫다면 데코레이터가 상속한 원래 객체를 주입하면 될 것 입니다!

또한 내부에 Component 를 가지고 있는 것은 원 객체의 기능도 호출해야 하기 때문입니다. 원 기능 또한 작동해야 하기 상속한 메서드를 호출할 때 원 객체의 메서드를 호출하는 것입니다.

 

정리하자면 기본 기능의 보존을 하면서도 유연하게 확장을 하기 위해 이러한 구조를 채택했다고 생각해주시면 감사하겠습니다 🙂

 

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

님의 데코레이터 패턴과 관련하여 MessageDecorator 클래스가 Component 클래스를 구현함과 동시에 Component를 필드로 갖는 이유에 대한 설명을 찾으시는군요.

데코레이터 패턴에서는 하나의 객체에 추가적인 기능을 동적으로 추가할 때 사용됩니다. 기본적인 설계 원칙 중 하나는 클래스를 확장하여 기능을 추가하는 것보다는 객체의 구성을 통해 기능을 추가하는 것이 더 유연하다는 것입니다. 이 때문에 MessageDecoratorComponent 인터페이스를 구현하면서도 동시에 Component 타입의 객체를 내부에 포함하고 있습니다.

이 구조 덕분에 MessageDecorator 객체는 내부에 포함된 Component 객체의 operation 메서드를 호출하고 그 결과에 어떤 추가 작업(이 경우 메시지를 꾸미는 작업)을 수행할 수 있습니다. 이렇게 Component 인터페이스를 구현한 객체를 MessageDecorator의 생성자를 통해 전달받아 내부 속성으로 할당하는 것은 데코레이터 패턴이 다양한 Component 구현체에 대해 유연하게 기능을 추가할 수 있도록 해줍니다.

다른 예시를 보고 싶으시다면, 다음 링크를 참조하시면 도움이 될 수 있습니다: component 중복초기화 부분 추상클래스로 변경.

여기서는 데코레이터 패턴을 사용하여 Component의 중복 호출 부분을 추상 클래스로 분리하는 방법에 대한 구체적인 예제와 설명이 포함되어 있습니다. 이 예제에서도 Component 인터페이스를 필드로 갖는 Decorator 추상 클래스가 작성되어 있으며, 이를 상속받아 각각의 구체적인 데코레이터(MessageDecorator, TimeDecorator 등)에서 특정 기능을 추가하는 방식이 설명되어 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

0

blackhole124

생성자를 통해 전달받아 내부 속성으로 할당 : 의존성 추가

Component 인터페이스를 구현하는 것 : 기능 구체화
라고 이해 하면될까요?

어드바이스 순서 디폴트 기준이 궁금합니다.

0

52

1

AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?

0

79

2

구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?

0

53

1

TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?

0

53

1

Decorator 에서 추상메서드로 뺄때 질문 있습니다.

0

56

1

대상 클래스에 기본 생성자가 없을 때

0

74

1

스프링 부트 버전 4.0 aop 의존성 명칭 변경

1

352

2

final 키워드 사용 관련 질문

0

77

1

안녕하세요

0

64

1

ThradLocal 실무 사례

0

97

2

실무에서의 동시성 문제

0

62

1

로그 등 부가 기능에 대한 테스트코드

0

50

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

67

1

실무 멀티스레딩에 대한 궁금증

0

69

1

안녕하세요 질문있습니다

0

44

1

AspectV3 aop 실행 순서 문의 드립니다

0

38

1

MDC vs AOP 중에 고민중입니다.

0

74

1

순환참조

0

158

2

this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이

0

77

1

빈 후처리에 등록 질문 있습니다.

0

76

1

AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.

0

88

1

ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?

0

117

2

@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부

0

67

1

ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)

0

73

2