인프런 커뮤니티 질문&답변

pbs0216님의 프로필 이미지

작성한 질문수

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

Validator 분리2

WebDataBinder는 비효율적인거 아닌가요?

작성

·

111

1

코드 면에서는 깔끔하지만 WebDataBinder가 요청마다 새로 만들어진다면 그만큼 객체를 생성하는데 오버헤드가 발생하는 것 아닌가요? 싱글톤으로 관리할 수 있는 addItemV5에 비해서 성능적으로 좋지 않다고 느껴지는데 맞나요?

답변 1

5

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. pbs0216님

객체 생성 오버헤드

WebDataBinder가 요청마다 새로 생성되는 것은 사실이지만, 이로 인한 객체 생성 오버헤드는 보통 미미한 편입니다. Java에서의 객체 생성은 가벼운 연산이기 때문에, WebDataBinder와 같은 작은 객체의 생성 및 소멸이 성능에 큰 영향을 미치지 않습니다.

싱글톤과의 비교

반면, 싱글톤 패턴을 사용하면 객체 생성 비용을 줄일 수 있지만, 이는 특정 상황에서만 유리할 수 있습니다. 싱글톤 객체는 애플리케이션 전반에 걸쳐 공유되므로 상태를 가지지 않거나 상태를 적절히 관리해야 합니다. 하지만 WebDataBinder는 상태를 가질 수 있는 객체이며, 각 요청마다 서로 다른 바인딩 논리나 유효성 검사를 수행할 수 있기 때문에 요청마다 독립된 인스턴스를 생성하는 것이 더 적합합니다.

 

정리하자면 WebDataBinder는 요청마다 다른 상태를 가질 수 있습니다. 따라서 싱글톤으로 설계할 수 없습니다. (멀티 스레드 이슈 발생)

그리고 자바에서 단순한 객체의 생성과 GC는 성능에 영향을 거의 주지 않습니다. 우리가 성능 최적화를 고민할 때는 성능에 진짜 영향을 주는 부분에 집중해서 최적화를 해야 합니다. 특히 웹 애플리케이션의 경우 외부 네트워크 접근이나, 데이터베이스 쿼리등에서 성능 병목이 주로 발생합니다.

예를 들어서 외부 네트워크 호출 1번은 약 10만번 이상의 메모리를 사용하는 연산과 비슷하다고 생각하시면 됩니다.

감사합니다.

pbs0216님의 프로필 이미지

작성한 질문수

질문하기