이벤트 페이로드 객체의 생성 방식이 팩토리 메서드 패턴이 아닌 빌더 패턴인 이유가 궁금합니다!.
안녕하세요, 강사님
덕분에 많은 인사이트를 얻으며 성장중인 수강생입니다ㅎㅎ
다름이 아니라 이벤트 페이로드 타입의 생성 방식이 팩토리 메서드 패턴이 아닌 빌더 패턴인 이유가 궁금합니다!
빌더 패턴의 장점은 생성자 오버로딩이 많을 때, 간편하게 사용할 수 있다는 장점이 있지만 필수인 필드에 null 이 들어갈 수 있다는 단점이 있다고 생각합니다.
그래서, 저는 빌더 패턴을 해당 객체의 필드 중 null 이 들어갈 수 있는 필드가 많을 때 사용하는 걸 선호하다 보니, 이벤트 페이로드 타입을 생성 할 때 일부 필드에 null 이 들어가는 걸까? 란 궁금증으로 질문이 생기게 되었습니다.
빌더 패턴에 대한 강사님의 의견이 궁금하며 이벤트에 기존에 사용하신 팩토리 메서드 대신 빌더 패턴을 사용하신 계기가 궁금합니다!
감사합니다 :)
Answer 2
0
종혁님, 안녕하세요!
강의 통해서 잘 성장해주고 계시다니 감사하네요!
질문 주신 부분에 대해서는 팩토리 메소드의 장점에 대해서 찾아보면 더욱 와닿으실 것 같습니다.
동일한 객체 생성이더라도 여러 의도로 나뉠 필요가 있다면, 메소드 네이밍으로 그 의도를 명확하게 드러낼 수 있을 것이고요.
단순히 필드 값을 assign 하고 어떠한 의도를 드러낼 필요가 없다면 그냥 빌더 패턴을 써도 무방합니다.
하지만 그 의도를 명확하게 드러내고 싶거나, 부가적인 로직이 필요할 때 팩토리 메소드 내부로 캡슐화할 수도 있습니다.
null에 대해서도 결국 값에 대한 검증이나 부가적인 로직이 필요한 상황을 말씀하신 것 같아요, 이 경우에도 말씀하신대로 빌더 보단 팩토리 메소드를 활용하는게 위에 언급된 이점들이 있습니다.
그렇기 때문에 개인적으로 팩토리 메소드를 선호하고 활용하고 있네요!
최근에 유사한 질문을 받았던 게 있어서 참고해보셔도 좋을 것 같습니다!
0
안녕하세요, 인프런 AI 인턴입니다. 종혁님.
이벤트 페이로드 객체의 생성 방식으로 빌더 패턴을 선택한 이유에 대해 궁금하셨군요. 빌더 패턴은 복잡한 객체 생성 시 유용한 방법 중 하나로, 다음과 같은 장점들이 존재합니다:
빌더 패턴의 장점:
가독성 향상: 빌더 패턴은 메서드 체이닝을 통해 객체를 구성할 수 있어, 코드의 가독성을 높입니다. 특히, 필드가 많거나 선택사항이 많은 객체 생성 시 편리합니다.
유연한 객체 생성: 필드의 순서나 개수에 상관없이 객체를 유연하게 구성할 수 있으며, 필요한 필드만 선택적으로 설정할 수 있습니다.
변경에 강한 구조: 새로운 필드가 추가되거나 일부 필드가 변경될 때, 기존 코드를 크게 수정하지 않아도 됩니다. 이는 코드 유지보수성을 향상시킵니다.
빌더 패턴을 선택한 이유:
이벤트 페이로드 객체들은 일반적으로 다양한 속성을 가질 수 있으며, 때때로 선택적인 속성을 포함할 수 있습니다. 이런 경우 빌더 패턴을 사용하면 필수/옵션 필드를 유연하게 관리할 수 있습니다.
팩토리 메서드 패턴은 객체 생성 로직을 캡슐화하여 의도를 명확하게 드러낸다는 장점이 있지만, 모든 필드 또는 상태를 한꺼번에 설정해야 한다면 불편할 수 있습니다. 반면 빌더 패턴은 이러한 상황에서 더 적합할 수 있습니다.
빌더 패턴을 활용하면 클라이언트 코드는 명확하게 어떤 필드를 설정하고 있는지를 빠르게 확인할 수 있어 유지보수와 확장성 측면에서 유리합니다.
기존에 팩토리 메서드를 사용하시다 빌더 패턴으로 변경하신 이유는 객체 생성의 유연성과 명확성을 고려한 결정일 수 있습니다. 특히, 대규모 시스템에서 다양한 객체 생성 시나리오가 발생하기 때문에, 이런 상황에서 빌더 패턴은 매우 유효하게 작용할 수 있습니다.
만약 이 주제와 관련된 더 많은 정보를 원하신다면 아래 유사한 질문/답변을 참고해 주세요:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
consumer에서 에러가 발생할 경우 데이터 유실 문의
0
38
2
게시글 테스트 데이터 삽입
0
43
2
정렬, 필터, 검색 등의 조건이 붙을 경우 최적화할 수 있는 방법이 무엇이 있을까요?
0
95
2
좋아요 기능 정합성 보장 방법
0
90
2
좋아요 동시성처리 최적의 선택?
1
115
2
프론트엔드 msa 환경 api 주소 통합? 과 서버끼리 통신 방식에대해
0
85
2
안녕하세요 무한스크롤 강의듣다가 질문이 있습니다.
0
54
1
조회수 조회 로직 질문
1
64
2
비로그인 유저도 어뷰징 방지 정책
1
63
2
CommentServiceTest의 테스트 로직 질문
0
50
2
무한 스크롤 방식에서 페이지 번호 방식 쿼리의 문제점 의문
1
69
2
path 쿼리 관련 질문드립니다!
0
55
2
antigravity 에디터를 쓰신다면 종료해주세요
1
122
0
프로젝트 구조
0
83
2
article_like_count api test
0
70
2
[33. 좋아요 수 구현] 에서 테스트 하는 화면 동시성 문제
0
88
2
findByPath에서 articleId로도 검색을 해야 할 것 같아요.
0
87
3
jpa ddl-auto none을 하는 이유와 join 방법
0
92
2
팩터리 메소드와 response 객체 사용 이유가 궁금합니다!
0
85
2
커서 기반 페이지네이션 과 무한 스크롤링
0
96
2
게시글 생성 로직에서 오류 발생시 redis 게시글 수 되돌리기
0
95
2
멀티 모듈이 아닌 MSA 환경에서 common
0
146
2
2Depth 강의 도중 궁금한 점 있어요!!
0
73
2
샤딩에 대해서 궁금점있습니다.
0
112
2

