inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

템플릿 메서드 패턴 - 예제3

Slf4j log 관련 오류

425

Jiwon

작성한 질문수 5

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
 
안녕하세요 영한님 항상 좋은 강의 감사드립니다.
 
templateMethodV2 를 작성하는 과정에서 오류가 발생했습니다.
'log' has private access in 'com.example.advance.template.code.AbstractTemplate'
위와 같은 컴파일 오류인데요
 
제 코드는 아래와 같습니다
package com.example.advance.template;

import com.example.advance.template.code.AbstractTemplate;
import com.example.advance.template.code.SubclassLogic1;
import com.example.advance.template.code.SubclassLogic2;
import org.junit.jupiter.api.Test;

public class TemplateMethodTest {

@Test
void templateMethodV1() {
AbstractTemplate template1 = new SubclassLogic1();
template1.execute();

AbstractTemplate template2 = new SubclassLogic2();
template2.execute();
}

@Test
void templateMethodV2() {
AbstractTemplate template = new AbstractTemplate() {
@Override
protected void call() {
log.info("비즈니스 로직1 실행");
}
};
log.info("클래스 이름1={}", template.getClass());
template.execute();

AbstractTemplate template2 = new AbstractTemplate() {
@Override
protected void call() {
log.info("비즈니스 로직2 실행");
}
};
log.info("클래스 이름2={}", template2.getClass());
template2.execute();
}
}


 

 

참고로 intellij 롬복 플러그인 설치했고, build.gradle 에서 아래 코드도 추가되어 있는 상태입니다.

testCompileOnly 'org.projectlombok:lombok'
testAnnotationProcessor 'org.projectlombok:lombok'

 

spring 디자인-패턴

답변 1

2

David

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

클래스 상단에 @Slf4j 애노테이션이 빠진 것 같습니다. 추가하고 다시 시도해보시겠어요?

감사합니다.

0

Jiwon

덕분에 해결했습니다 빠른 답변 감사드립니다!

SpringBoot 4.0.6 버전에서 PackageLogTracePostProcessor exception

0

84

3

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

0

75

1

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

0

102

2

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

0

73

1

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

0

69

1

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

0

63

1

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

0

83

1

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

1

407

2

final 키워드 사용 관련 질문

0

85

1

안녕하세요

0

75

1

ThradLocal 실무 사례

0

106

2

실무에서의 동시성 문제

0

73

1

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

0

60

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

77

1

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

0

81

1

안녕하세요 질문있습니다

0

49

1

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

0

45

1

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

0

85

1

순환참조

0

168

2

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

0

83

1

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

0

85

1

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

0

98

1

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

0

122

2

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

0

76

1