Book/모던 자바 인 액션(8)
-
CHAPTER7 - 병렬 데이터 처리와 성능(1)
목차.1. 병렬 스트림으로 데이터를 병렬 처리하기2. 병렬 스트림의 성능 분석 1. 병렬 스트림 컬렉션에 parallelStream을 호출하면 병렬 스트림이 생성된다. 병렬 스트림이란 각각의 스레드에서 처리할 수 있도록 스트림 요소를 여러 청크로 분할한 스트림이다. 따라서 병렬 스트림을 이용하면 모든 멀티코어 프로세서가 각각의 청크를 처리하도록 할당할 수 있다. 예제로 살펴보자 숫자 n을 인수로 받아서 1부터 n까지의 모든 숫자의 합계를 반환하는 메서드를 구현한다고 가정하자. 숫자로 이뤄진 무한 스트림을 만든다음에 인수로 주어진 크기로 스트림을 제한하고, 두 숫자를 더하는 BinaryOperator로 리듀싱 작업을 해보자public long sequentialSum(long n) { return ..
2025.02.28 -
CHAPTER6 - 스트림으로 데이터 수집(2)
목차.1. 데이터 그룹화와 분할2. 자신만의 커스텀 컬렉터 개발 1. 그룹화트랜잭션 통화 그룹화 예제에서 확인했듯이 명령형으로 그룹화를 구현하려면 까다롭고, 할일이 많으며, 에러도 많이 발생한다.Map> transactionsByCurrency = new HashMap();for (Transaction transaction : TransactionExample.transactions) { Currency currency = transaction.getCurrency(); List transactionsForCurrency = transactionsByCurrency.get(currency); if (transactionsForCurrency == null) { transac..
2025.02.25 -
CHAPTER6 - 스트림으로 데이터 수집(1)
목차.1. Collectors 클래스로 컬렉션을 만들고 사용2. 하나의 값으로 데이터 스트림 리듀스하기3. 특별한 리듀싱 요약 연산 컬렉터를 어떻게 활용할 수 있을까? 예제를 먼저 살펴보자. 어떤 트랜잭션 리스트가 있고 이들을 액면 통화로 그룹화한다고 가정하자.Map> transactionsByCurrency = new HashMap();for (Transaction transaction : TransactionExample.transactions) { Currency currency = transaction.getCurrency(); List transactionsForCurrency = transactionsByCurrency.get(currency); if (transactions..
2025.02.21 -
CHAPTER5 - 스트림 활용(2)
목차.1. 특정 범위의 숫자와 같은 숫자 스트림 사용하기2. 다중 소스로부터 스트림 만들기3. 무한 스트림 1. 숫자형 스트림앞서 reduce 메서드로 스트림 요소으 ㅣ합을 구하는 예제를 살펴봤다.int calories = DishExample.menu.stream() .map(Dish::getCalories) .reduce(0, Integer::sum); 사실 위 코드에는 박싱 비용이 숨어있다. 내부적으로 합계를 계산하기 전에 Integer를 기본형으로 언박싱해야 한다. 위와 같은 상황에서는 효율적으로 처리할 수 있도록 기본형 특화 스트림을 사용할 수 있다. 1.1 기본형 특화 스트림자바 8에서는 세 가지 기본형 특화 스트림을 제공한다. 스트림 API는 박싱 비용을 피할 수 ..
2025.02.17 -
CHAPTER5 - 스트림 활용(1)
목차.1. 필터링, 슬라이싱, 매칭2. 검색, 매칭, 리듀싱 1. 필터링1.1 프리디케이트 필터링스트림 인터페이스는 filter 메서드를 지원한다. filter 메서드는 프레디케이트(불리언을 반환하는 함수)를 인수로 받아서 프레디케이트와 일치하는 모든 요소를 포함하는 스트림을 반환한다.List vegetarianMenu = DishExample.menu.stream() .filter(Dish::isVegetarian) .toList(); 1.2 고유 요소 필터링스트림은 공유 요소로 이루어진 스트림을 반환하는 distinct 메서드도 지원한다.(고유 여부는 스트림에서 만든 객체의 hashCode, equals로 결정된다) 예를 들어 다음 코드는 리스트의 모든 짝수를 선택하고 중복..
2025.02.14 -
CHAPTER4 - 스트림
목차. 1. 스트림이란 무엇인가?2. 컬렉션과 스트림3. 내부 반복과 외부 반복4. 중간 연산과 최종 연산 1. 스트림이란 무엇인가?스트림은 자바 8 API에 새로 추가된 기능이다. 스트림을 이용하면 선언형(데이터 처리를 질의로 표현)으로 컬렉션 데이터를 처리할 수 있다.또한 스트림을 이용하면 멀티스레드 코드를 구현하지 않아도 데이터를 투명하게 병렬로 처리할 수 있다. 스트림을 사용하지 않는 코드List lowCaloricDishes = new ArrayList();//누적자로 요소 필터링for (Dish dish : DishExample.menu) { if (dish.getCalories() () { @Override public int compare(Dish o1, Dish o2..
2025.02.12 -
CHAPTER3 - 람다 표현식
목차. 1. 람다란 무엇인가?2. 실행 어라운드 패턴3. 함수형 인터페이스, 형식 추론4. 메서드 참조5. 람다 만들기 1. 람다란 무엇인가?람다 표현식은 메서드로 전달할 수 있는 익명 함수를 단순화한 것이라고 할 수 있다. 람다 표현식에는 이름은 없지만, 파라미터 리스트, 바디, 반환 형식, 반생할 수 있는 예외 리스트는 가질 수 있다. 람다의 특징을 살펴보자 * 익명- 보통의 메서드와 달리 이름이 없어 익명이라고 표현한다. 구현해야 할 코드에 대한 걱정거리가 줄어든다. * 함수- 람다는 메서드처럼 특정 클래스에 종속되지 않으므로 함수라고 부른다. 메서드처럼 파라미터 리스트, 바디, 반환 형식 가능한 예외 리스트를 포함한다. * 전달- 람다 표현식을 메서드 인수로 전달하거나 변수로 저장할 수 있다...
2025.01.16 -
CHAPTER2 - 동작 파라미터화 코드 전달
목차. 1. 변화하는 요구사항에 대응2. 동작 파라미터화3. 익명 클래스4. 람다 표현식 미리보기 동작 파라미터화를 이용하면 자주 바뀌는 요구사항에 효과적으로 대응할 수 있다.동작 파라미터화란 아직은 어떻게 실행할 것인지 결정하지 않은 코드 블록을 의미한다. 이 코드 블록은 나중에 실행될 메서드의 인수로 코드 블록을 전달할 수 있다. 1. 변화하는 요구사항에 대응하기예제를 보면서 변화에 대응하는 코드를 구현해보자. 기존의 농장 재고목록 애플리케이션에 리스트에 녹색 사과만 필터링하는 기능을 추가한다고 가정하자. 1.1 첫 번째 시도 : 녹색 사과 필터링public static List filterGreenApples(List inventory) { List result = new ArrayLis..
2025.01.07