Inflearn brand logo image

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

이찬원님의 프로필 이미지
이찬원

작성한 질문수

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

중간 연산

중간연산 sorted에 대해서 질문드립니다

작성

·

74

0

중간 연산 강의를 듣던 중 궁금한 점이 생겨 질문드립니다!

강의를 통해 Java의 스트림은 lazy하게 동작하며, 요소가 하나씩 흐르면서 중간 연산을 거쳐 최종 연산으로 전달된다고 배웠습니다.

그런데 sorted는 정렬을 위해 모든 요소를 모아야 하므로, 다른 중간 연산들과 달리 lazy하게 하나씩 처리할 수는 없을 것 같습니다.

이 경우 sorted는 전체 요소를 한 번에 처리하고 나서야 다음 연산으로 넘어가는 건가요?

그렇다면 sorted는 중간 연산이지만 실제로는 최종 연산처럼 동작하는 게 아닌가요?

답변 1

0

안녕하세요, 인프런 AI 인턴입니다.
이찬원님께서 질문하신 내용은 Java 스트림의 중간 연산인 sorted에 대한 중요한 개념을 다루고 있습니다.

스트림의 sorted 메소드는 중간 연산이지만, 말씀하신 대로 모든 요소를 수집한 뒤 정렬을 진행하기 때문에 일반적인 중간 연산과는 조금 다르게 동작합니다. 일반적인 중간 연산들은 lazy하게 요소를 하나씩 처리하며 다음 연산으로 전달되지만, sorted는 모든 요소가 정렬된 후에야 다음 단계로 진행할 수 있습니다. 이는 내부적으로 모든 데이터를 메모리에 모은 뒤 정렬하기 때문입니다.

그렇다고 해서 sorted가 최종 연산처럼 동작한다는 의미는 아닙니다. 최종 연산은 스트림의 소비 작업으로, 결과가 반환되어 스트림이 종료됩니다. 반면 sorted는 결과적으로 스트림을 반환하여 이후에 다른 연산이 체이닝(chaining)될 수 있기 때문에 중간 연산으로 분류됩니다.

더 자세한 설명이 필요하시다면, 다음의 관련 질문과 답변을 참고해 보세요:
- Java 스트림에서의 중간 연산과 최종 연산의 차이
- 스트림의 동작 방식을 이해하기 위한 추가 예제

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

이찬원님의 프로필 이미지
이찬원

작성한 질문수

질문하기