강의

멘토링

로드맵

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

zbass님의 프로필 이미지
zbass

작성한 질문수

김영한의 실전 자바 - 고급 3편, 람다, 스트림, 함수형 프로그래밍

실무에서의 커스텀 Collector 사례 여부

작성

·

14

0

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

[질문 내용]

안녕하세요!

현재 Stream API Collector 65강까지 수강 완료한 수강생입니다.

먼저 강사님 덕분에 자바에 대해서 계속 공부하는 시간이 정말 즐겁니다! 감사합니다!

 

아래와 같은 질문 사항이 있어 남깁니다!


실무에서 Collector를 직접 구현해야 하는 상황은 어떤 경우가 많나요?

직접 Collector를 구현해야 하는 상황이 생긴다면 병렬 스트림에서도 안전하게 동작하도록 어떤 설계 포인트를 가장 중요하게 봐야 할까요?

 

다소 정답이 없는 질문이지만 방향성과 강사님의 생각이 궁금합니다! 😃

감사합니다.

답변 1

0

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

Stream API의 Collector를 직접 구현해야 하는 상황은 주로 기본 제공 Collector로는 해결하기 어려운 복잡한 집계 로직이 필요할 때 발생합니다. 예를 들어, 집계되지 않은 데이터의 특정 구조로 변환이 필요하거나, 동일한 스트림을 여러 번 순회하여 복합적인 결과물을 만들어야 할 때가 있습니다.

Collector를 병렬 스트림에서 안전하게 동작하도록 설계하려면 다음과 같은 포인트를 고려해야 합니다:

  1. 불변성: Collector가 불변 객체를 생성하도록 설계하면, 병렬 처리 시 스레드 안전성을 확보할 수 있습니다.
  2. 병합 메서드: 다양한 스레드에서 Partial 결과를 병합할 때 충돌이 발생하지 않도록 combiner 메서드를 신중히 구현해야 합니다.
  3. 컨커런트 컬렉션: 가능하다면, java.util.concurrent 패키지에 있는 컨커런트 컬렉션을 활용하여 기본적으로 스레드 안전성을 보장할 수 있습니다.

이와 관련된 강사님의 구체적인 설명이나 사례는 아래의 유사한 질문 답변에서 확인하실 수 있습니다:

자바 함수형 인터페이스 질문
위 답변에서는 함수형 인터페이스와 그 사용 사례에 대해 설명하고 있으며, 커스텀 구현의 필요성에 대한 관점을 알아보실 수 있습니다.

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

zbass님의 프로필 이미지
zbass

작성한 질문수

질문하기