data:image/s3,"s3://crabby-images/5b8c2/5b8c2d1dfd247c8122a1744568e90234e38d0f5c" alt=""
목차
Spring 핵심원리 고급편 - Decorator Pattern 적용
@Slf4j public class TimeDecorator implements Component{
private Component component;
public TimeDecorator(Component component) { this.component = component; }
@Override public String operation() { log.info("TimeDecorator 실행"); long startTime = System.currentTimeMillis();
String result = component.operation(); long endTime = System.currentTimeMillis(); long resultTime = endTime - startTime; log.info("TimeDecorator 종료 resultTime = {}ms", resultTime); return null; } }
|
@Test void decorator2(){ Component realComponent = new RealComponent(); Component messageDecorator = new MessageDecorator(realComponent); Component timeDecorator = new TimeDecorator(messageDecorator); DecoratorPatternClient client = new DecoratorPatternClient(timeDecorator); client.execute(); }
|
data:image/s3,"s3://crabby-images/70178/7017884a38e81d684af66dd6d2c3d465364b9223" alt=""
data:image/s3,"s3://crabby-images/b05c2/b05c225b1d214a937313c0f2d1050fce8ebae90c" alt=""
Decoratro Pattern 은 항상 내부에 꾸며 줄 대상(Component) 가 존재해야 한다.