정의된 연산이 아닌 프로그래머가 직접 구현한 연산을 적용
T reduce(T identify, BinaryOperator<T> accumulator)의 형식으로 사용
최종 연산으로 스트림의 요소를 소모하며 연산을 수행
Reduce()메서드의 두 번째 요소로 전달되는 람다식에 따라 다양한 기능을 수행 할 수 있다.
람다식을 직접 구현하거나 식이 긴 경우BinaryOperator를 구현한 클래스를 사용한다.
Ex)
Arrays.stream(arr).reduce(0, (a,b) -> a+b));
Ex)
import java.util.Arrays;
import java.util.function.BinaryOperator;
class CompareString implements BinaryOperator<String>{
@Override
public String apply(String s1, String s2) {
{if(s1.getBytes().length>= s2.getBytes().length) return s1;
else return s2;}
}
}
public class ReduceTest {
public static void main(String[] args) {
String greetings[] = {"hello","hi","Good morning","안녕하세요"};
System.out.println(Arrays.stream(greetings).reduce("",(s1, s2) ->
{if(s1.getBytes().length>= s2.getBytes().length) return s1;
else return s2;}
));
String str = Arrays.stream(greetings).reduce(new CompareString()).get();
System.out.println(str);
}
}
한글이 byte가 더 크기 때문에 byte로 계산해보면 가장 긴 “안녕하세요”가 출력된다.