inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

전략 패턴 - 예제3

동시성 이슈 - 전략패턴

해결된 질문

635

윤승환

작성한 질문수 5

0

전략 패턴 - 예제 3 7:50초까지 듣고 질문 남깁니다.

문맥(Context)에 로직(Strategy)을 담기 위해 두가지 방법을 알려주셨습니다.

  1. Context 필드에 Strategy 생성자 주입

  2. Context 메소드에 Strategy 위임(?)

 

1번 방식에서 생성자 주입시 Setter를 이용하여 필드의 전략을 바꿔서 실행하는 경우 '동시성 이슈'가 발생할 수 있다고 말씀하셨는데, 동시성 측면에서 2번과 차이가 있을까요?

 

디자인-패턴 spring

답변 1

5

김영한

안녕하세요. 윤승환님

생성자에서 주입하게 되면 애플리케이션 실행 시점에 최초에 딱 1번만 설정하고 끝이납니다.

메소드나 setter를 이용하게 되면 누군가 실수로 중간에 변경할 수도 있습니다.

이 경우 setter로 중간에 변경하는 타이밍에 동시성 문제가 발생할 수 있습니다.(이미 고객 요청이 막들어오고 있는 상황이니까요)

반면에 생성자를 주입하게 되면 고객의 요청이 들어오기 전에 모든 것이 완성이 됩니다. (setter 주입도 처음에 고객의 요청이 들어오기전에 완성이 됩니다. 대신에 누군가 중간에 변경할 때 문제가 될 수 있습니다.)

여기서 핵심은 동시성이 사실 문제라기 보다는 중간에 변경하면 안되는 것을 setter가 있다고 누군가 실수로 중간에 변경하는 것 자체가 문제를 열어두게 된다는 점입니다.

감사합니다.

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

0

57

1

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

0

84

2

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

0

60

1

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

0

55

1

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

0

57

1

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

0

77

1

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

1

376

2

final 키워드 사용 관련 질문

0

78

1

안녕하세요

0

68

1

ThradLocal 실무 사례

0

100

2

실무에서의 동시성 문제

0

65

1

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

0

51

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

67

1

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

0

70

1

안녕하세요 질문있습니다

0

45

1

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

0

39

1

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

0

77

1

순환참조

0

162

2

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

0

78

1

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

0

79

1

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

0

91

1

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

0

118

2

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

0

70

1

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

0

73

2