[ch.07] 스트림 사용
·
함수형 프로그래밍
원시 스트림자바에서 제네릭은 객체 기반 타입에서만 작동한다.Stream는 int와 같은 기본값 시퀀스에 사용될 수 없다.자바는 원시 타임과 그에 상응하는 객체 타입 간의 자동변환(AutoBoxing)을 지원한다.Stream longStream = Stream.of(5L, 23L, 42L); 오토 박싱의 문제1. 원시 타입의 값을 객체로 변환할 때 오버헤드가 발생스트림 파이프라인에서 래퍼 타입의 지속적인 생성으로 인해 오버헤드가 누적될 수 있다.2. null 값의 존재 가능성원시 타입을 객체로 바로 변환할 때는 null이 생기지 않는다.파이프라인 내의 특정 연산에서 래퍼 타입을 처리해야 한다면 null 값이 반환될 가능성이 있다.일반적으로 원시 스트림을 사용하는 경우는 최적화를 위해 대규모 데이터를 병렬 ..
[ch.06] 스트림을 이용한 데이터 처리
·
함수형 프로그래밍
데이터 소스를 일관되고 선언적인 방식으로 처리할 수 있게 해주는 API스트림은 데이터의 흐름을 추상화한 개념으로, 데이터를 필터링, 매핑 등의 작업을 수행할 수 있게 해 준다.데이터 처리에 대한 선언적이고 지연 평가된 접근법을 제공한다. 1. 반복을 통한 데이터 처리모든 데이터 처리는 파이프라인 방식으로 작동하는데, DB에서 조회한 데이터를 컬렉션 자료 구조에 넣거나 필터링, 변환 같은 다양한 작업들을 거쳐 결과를 제공한다.public static void main(String[] args) { List list = Arrays.asList("apple", "banana", "apricot", "orange"); List newList = new ArrayList(); for (Strin..
[ch.05] 레코드
·
함수형 프로그래밍
레코드는 간단한 구문으로 다양한 형태의 데이터를 집계할 수 있는 기능을 가진다. 데이터 집계란 특정 목적을 위해 데이터를 모으고 구조화하는 것을 의미한다.대표적으로 튜플이 있다. 튜플여러 값을 하나의 묶음으로 저장할 수 있는 자료형1. 구조적 튜플데이터의 순서와 개수를 기준으로 정의데이터의 타입과 순서에만 의존하므로 인덱스를 통해서만 접근이 가능하다.// Java는 기본적으로 튜플 제공 x, 외부 라이브러리나 레코드를 통해 유사한 구조를 만들 수 있다.//org.apache.commons.lang3.tuple.Pair 라이브러리를 사용한 구조적 튜플 예제public class TupleExample { public static void main(String[] args) { Pair p..
[ch.04] 가변성 & 불변성
·
함수형 프로그래밍
가변성자바에서는 객체의 상태를 가변 형태로 캡슐화한다.객체의 필드를 private 으로 선언하여 외부에서 직접 접근하지 못하도록 한다.대신, getter와 setter 등을 통해 객체 내부에 접근하고 변경할 수 있도록 캡슐화한 것이다.가변 상태를 다루는 자바 객체들이 있는데 이들은 컴포넌트 간의 재사용성을 향상시키기 위해 상태값을 캡슐화하도록 설계되었다.POJO /  JavaBean  1. POJO특별한 제한이나 요구 사항 없이 단순한 자바 객체를 의미한다.비즈니스 로직 상태를 캡슐화하는 것이 목적이며, 불변성을 갖도록 설계할 수 있다.가변 상태를 가진 객체 지향적인 컨텍스트에서 유연하게 작동하도록 필드에 getter와 setter를 제공한다.public class Person { private S..