inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

쓰레드 로컬 - 주의사항

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

115

rlawhdals6

작성한 질문수 1

0

ThreadLocal사용시 remove가 필요한 이유가 was서버는 http요청이 끝나도 객체 생명주기가 끝나는게 아닌 쓰레드풀을 재사용하기 때문에 remove를 해야 해야 하는걸로 이해 했습니다.

 

물론 강의 예시에선 로그를 찍어야 하기 때문에 전역변수를 사용하는게 맞지만 만약에 ThreadLocal을 메서드 내에서 지역변수로 사용해도 되는 경우가 있다면 굳이 remove를 할 필요가 없을까요?

spring 디자인-패턴

답변 2

1

김영한

안녕하세요. rlawhdals6님

ThreadLocal은 지역변수로 사용해도 remove를 사용해야 합니다.

왜냐하면 ThreadLocal의 값은 Thread 객체 내부의 ThreadLocalMap에 저장되기 때문입니다.

결과적으로 스레드 객에 안에 값이 저장됩니다.

물론 스레드 풀을 사용하지 않고, 스레드가 곧바로 종료되는 구조라면 문제가 되지 않습니다.

하지만 정말 메서드 내부에서만 쓰고, 깊은 호출 스택에 값 전달이 필요 없다면 그냥 일반 지역변수를 사용하면 됩니다.


ThreadLocal을 쓴다는 것 자체가 "파라미터로 넘기기 귀찮거나 프레임워크 훅에서 꺼내 써야 해서 스레드 컨텍스트에 숨겨둔다"는 의도가 대부분이기 때문입니다.

감사합니다.

1

rlawhdals6

아 단순 객체가 아니라 깊숙히 들어가는 형태군요! 자세한 답변 정말 감사합니다!

0

인프런 AI 인턴

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

ThreadLocal을 사용하는 이유와 그것을 올바르게 관리하는 방법에 대해 좋은 질문을 주셨네요. ThreadLocal을 사용할 때 가장 중요한 점 중 하나는 메모리 누수를 방지하기 위해 remove() 메소드를 호출하는 것입니다. 이는 특히 ThreadLocal을 전역 혹은 인스턴스 변수로 사용할 때 중요합니다.

하지만, 질문 주신 상황처럼 ThreadLocal을 메서드 내의 지역변수로 사용한다면 메서드 호출이 끝난 후에는 메모리에 더 이상 참조가 남아있지 않기 때문에 remove()를 호출할 필요가 없습니다. 지역변수는 메서드 스택에 저장되고, 메서드 실행이 완료되면 자동으로 메모리에서 제거되기 때문에 특별한 처리가 필요하지 않습니다.

이와 관련된 추가 정보는 다음의 게시물에서 확인할 수 있습니다:

이해에 도움이 되셨길 바랍니다. 더 궁금하신 점이 있으시면 언제든 질문해주세요.

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

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

0

50

1

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

0

77

2

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

0

49

1

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

0

53

1

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

0

55

1

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

0

74

1

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

1

334

2

final 키워드 사용 관련 질문

0

74

1

안녕하세요

0

63

1

ThradLocal 실무 사례

0

97

2

실무에서의 동시성 문제

0

62

1

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

0

50

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

66

1

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

0

69

1

안녕하세요 질문있습니다

0

43

1

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

0

37

1

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

0

74

1

순환참조

0

157

2

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

0

77

1

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

0

73

1

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

0

86

1

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

0

65

1

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

0

69

2

빈으로 주입하지 않고 new로 객체 생성해도 되는데, 왜 ThreadLocal을 사용하나요?

0

68

1