프로그래밍 노트

JobParameter는 Spring Batch를 실행할 때 내/외부에서 받는 파라미터를 뜻하며, JobParameter를 사용하기 위해선 @StepScope, @JobScope 를 선언해야 한다. @JobScope Step 선언문에서 사용 @Bean public Job simpleJobExample() { return jobBuilderFactory.get("simpleJobExample") .start(simpleStep1(null)) .next(simpleStep2()) .build(); } @Bean @JobScope public Step simpleStep1(@Value("#{jobParameters[requestDate]}") String requestDate) { return stepBuil..
캡슐화 객체를 설계하기 위한 가장 기본적인 아이디어 변경의 정도에 따라 구현-인터페이스를 분리하고 외부에서는 인터페이스에만 의존하도록 관계를 조절하는 것 → (불안정한 부분 / 안정적인 부분을 분리해서 변경의 영향을 통제) 캡슐화? 객체지향에서 가장 중요한 원리 상태와 행동을 하나의 객체 안으로 모아 내부 구현을 외부로부터 감추자. (외부에서 알 필요 없는 부분을 감춤으로써 대상을 단순화시킴) ⇒ 불안정한 구현 세부사항을 안정적인 인터페이스 뒤로 숨김(캡슐화) 응집도와 결합도 응집도 모듈에 포함된 내부 요소들이 연관돼 있는 정도 모듈 내의 요소들이 하나의 목적을 위해 긴밀하게 협력한다면 그 모듈은 높은 응집도를 가진다. 변경의 관점 변경(요구사항)이 발생했을 때 모듈 내부에 발생하는 변경의 정도 응집도 ..
1. 함수 추출하기 (Extract Function) 코드 조각을 찾아 무슨 일을 하는지 파악한 다음, 독립된 함수로 추출하고 목적에 맞는 이름을 붙인다. When? 언제 독립된 함수로 묶어야 할지에 관한 의견이 분분함 길이 기준 재사용성 기준 코드가 무슨 일을 하는지 파악하는데 시간이 걸린다면, 그 부분을 함수로 추출한 뒤 '무슨 일'에 걸맞는 이름을 짓자. 목적과 구현을 분리 Why? 함수의 목적이 눈에 확 들어오고, 본문 코드(목적을 이루기 위해 구체적으로 수행하는 일)에 대해서는 더 이상 신경 쓸 필요가 없다. 함수명으로 함수의 목적을 나타내고, 그 목적을 이루기 위한 구현코드를 분리한다. function printOwing(invoice) { printBanner(); let ou..
Collectors 클래스에 존재하는 정적 팩토리 메서드 (https://docs.oracle.com/javase/8/docs/api/java/util/stream/Collectors.html) 팩토리 메서드 반환 형식 비고 toList List 스트림 항목을 리스트로 수집 toSet Set 스트림 항목을 집합으로 수집 toCollection Collection 스트림의 모든 항목을 발행자가 제공하는 컬렉션으로 수집 counting Long 스트림 항목 수 계산 summingInt Integer 스트림 항목의 정수 프로퍼티 값 더함 averagingInt Double 스트림 항목의 정수 프로퍼티 평균값 계산 summarizingInt IntSummaryStatistics 최댓값, 최솟값, 합계, 평균 등..
자바 8의 함수형을 이용하면 가독성 있는 한 줄의 코드로 그룹화를 구현할 수 있다. 예를 들어 고기를 포함하는 그룹, 생선을 포함하는 그룹, 나머지 그룹으로 메뉴를 그룹화할 수 있다. 팩토리 메서드 Collectors.groupingBy를 이용하자. Map dishesByType = menu.stream().collect(groupingBy(Dish::getType)); {FISH=[parawns, salmon], OTHER=[french fries, rice, season fruit, pizza], MEAT=[pork, beef, chicken]} Dish.Type과 일치하는 모든 요리를 추출하는 함수를 groupingBy 메서드로 전달. 이 함수를 기준으로 스트림이 그룹화되므로 이를 분류 함수(cla..
컬렉터란 무엇인가? Collector 인터페이스 구현은 스트림의 요소를 어떤 식으로 도출할지 지정한다. 명령형 코드에서는 문제 해결하는 과정에서 다중 루프와 조건문을 추가하며 가독성과 유지보수성이 크게 떨어진다. 반면 함수형 프로그래밍에서는 필요한 컬렉터를 쉽게 추가할 수 있다. 고급 리듀싱 기능을 수행하는 컬렉터 collect로 결과를 수집하는 과정을 간단하면서도 유연한 방식으로 정의할 수 있다는 점이 컬렉터의 최대 장점이다. 스트림에 collect를 호출하면 스트림의 요소에 (컬렉터로 파라미터화된) 리듀싱 연산이 수행된다. 내부적으로 리듀싱 연산이 일어나는 모습 명령형 프로그래밍에서는 우리가 직접 구현해야 했던 작업이 자동으로 수행된다. collect에서는 리듀싱 연산을 이용해서 스트림의 각 요소를 ..
메뉴의 칼로리 합계를 reduce로 구할 수 있다. int calories = menu.stream() .map(Dish::getCalories) .reduce(0, Integer::sum); 사실 위 코드에는 박싱 비용이 숨어 있다. 내부적으로 합계를 계산하기 전에 Integer를 기본형으로 언박싱해야 한다. int calories = menu.stream() .map(Dish::getCalories) .sum(); 위와 같이 sum 메소드를 호출 할 수 없을까? map 메서드가 Stream를 생성하기 때문에 불가능 하다. 스트림의 요소 형식은 Integer 지만 (Stream) 인터페이스에는 sum 메서드가 없다. 다행히 스트리 API 숫자 스트림을 효율적으로 처리할 수 있도록 기본형 특화 스트림(p..
메뉴에서 칼로리가 가장 높은 요리는? 같이 스트림 요소를 조합해서 더 복잡한 질의를 표현하는 방법에 대해 알아보자. 이러한 질의를 수행하려면 Integer 같은 결과가 나올 때까지 스트림의 모든 요소를 반복적으로 처리해야 한다. 이런 질의를 리듀싱 연산(모든 스트림 요소를 처리해서 값으로 도출하는)이라고 한다. 1. 요소의 합 // for-each 사용 int sum = 0; for (int x : numbers) { sum += x; } // stream 사용 int sum = numbers.stream().reduce(0, (a, b) -> a + b); int sum = numbers.stream().reduce(0, Integer::sum); reduce는 두 개의 인수를 갖는다. 초깃값 스트림의..
1. Predicate가 적어도 한 요소와 일치하는지 확인 - anyMatch if(menu.stream().anyMatch(Dish::isVegetarian)) { System.out.prinln("The menu is (somewhat) vegetarian friendly!!"); } anyMatch는 불리언을 반환하므로 최종 연산이다. 2. Predicate가 모든 요소와 일치하는지 검사 - allMatch, noneMatch allMatch메서드는 anyMatch와 달리 모든 요소가 Predicate와 일치하는지 검사한다. boolean isHealthy = menu.stream().allMatch(d -> d.getCalories() < 1000); noneMatch는 allMatch와 반대 연..
public List findPrices(String product) { List priceFutures = shops.stream() .map(shop -> CompletableFuture.supplyAsync(() -> shop.getPrice(product), executor)) .map(future -> future.thenApply(Quote::parse)) .map(future -> future.thenCompose(quote -> CompletableFuture.supplyAsync(() -> Discount.applyDiscount(quote), executor))); return priceFutures.stream() .map(CompletableFuture::join) .coolect(..
깡냉쓰
'프로그래밍 노트' 카테고리의 글 목록 (7 Page)