본문 바로가기

분류 전체보기

(214)
[아이템 4] 인스턴스화를 막으려거든 private 생성자를 사용하라 [배경] 이따금 단순히 정적 메서드와 정적 필드만을 담은 클래스를 만들고 싶을 때가 있다. 객체 지향적이지는 않지만, 분명 나름의 쓰임새가 있다. java.lang.Math, java.util.Arrays처럼 기본 타입 값이나 배열 관련 메서드들을 모아놓을 수 있다. java.util.Collections처럼 특정 인터페이스를 구현하는 객체를 생성해주는 정적 메서드(혹은 팩터리)를 모아놓을 수도 있다. 자바8부터는 이런 메서드를 인터페이스에 넣을 수 있다. final 클래스와 관련한 메서드들을 모아놓을 때도 사용한다. final 클래스를 상속해서 하위 클래스에 메서드를 넣는 건 불가능하기 때문이다. [주의] 추상 클래스로 만드는 것으로는 인스턴스화를 막을 수 없다. 하위 클래스를 만들어 인스턴스화하면 그..
[아이템 3] private 생성자나 열거 타입으로 싱글턴임을 보증하라 [배경] 싱글턴(Singleton)이란 인스턴스를 오직 하나만 생성할 수 있는 클래스를 말한다. 클래스를 싱글턴으로 만들면 이를 사용하는 클라이언트를 테스트하기가 어려워질 수 있다. 타입을 인터페이스로 정의한 다음 그 인터페이스를 구현해서 만든 싱글턴이 아니라면 싱글턴 인스턴스를 가짜(mock) 구현으로 대체할 수 없기 때문이다. [싱글턴 만드는 방식 3가지] ※ 1,2 방식은 모두 생성자를 private으로 감춰두고, 유일한 인스턴스에 접근할 수 있는 수단으로 public static 멤버를 하나 마련해둔다. 1. public static 멤버가 final 필드인 방식 public class Elvis { public static final Elvis INSTANCE = new Elvis(); priv..
[아이템 2] 생성자에 매개변수가 많다면 빌더를 고려하라 [배경] 정적 팩터리와 생성자에는 똑같은 제약이 하나 있다. 선택적 매개변수가 많을 때 적절히 대응하기 어렵다는 점이다. [해결방법] 1. 점층적 생성자 패턴(telescoping constructor pattern) 필수 매개변수만 받는 생성자, 필수 매개변수와 선택 매개변수 1개를 받는 생성자, 선택 매개변수를 2개까지 받는 생성자, ... 형태로 선택 매개변수를 전부 다 받는 생성자까지 늘려가는 방식이다. 단점 매개변수 개수가 많아지면 클라이언트 코드를 작성하거나 읽기 어렵다. 클라이언트가 실수로 매개변수의 순서를 바꿔 건네줘도 컴파일러는 알아채지 못하고, 결국 런타임에 엉뚱한 동작을 하게 된다아이템51. 2. 자바빈즈 패턴(JavaBeans pattern) 매개변수가 없는 생성자로 객체를 만든 후..
[아이템 1] 생성자 대신 정적 팩터리 메서드를 고려하라 ※ 여기서 말하는 정적 팩터리 메서드 ≠ GoF의 팩터리 메서드 클래스는 클라이언트에 public 생성자 대신 (혹은 생성자와 함께) 정적 팩터리 메서드(static factory method)를 제공할 수 있다. 다음은 정적 팩터리 메서드에 흔히 사용하는 명명 방식들이다. from: 매개변수를 하나 받아서 해당 타입의 인스턴스를 반환하는 형변환 메서드 예) Date d = Date.from(instant); of: 여러 매개변수를 받아 적합한 타입의 인스턴스를 반환하는 집계 메서드 예) Set faceCards = EnumSet.of(JACK, QUEEN, KING); valueOf: from과 of의 더 자세한 버전 예) BigInteger prime = BigInteger.valueOf(Intege..
Chapter 2. 애자일 주요 원리: 자기 조직화, 린, 몰입 2.1 애자일 소프트웨어 개발 선언문의 이해 [배경] Jim Highsmith, Ken Schwaber 등 소프트웨어 개발 전문가들은 프로젝트를 복잡적응계(complex adaptive system)로 인식하고, 그동안 개발 과정에서 간과했던 구성원 간의 커뮤니케이션을 강조하면서 프로젝트 상황에 따른 적응형(adaptive) 개발 방법을 주장했다. Kent beck 역시 전통적 프로젝트 관리에서 문제가 되었던 중간 산출물 과용의 대안으로 코드 중심의 소프트웨어 개발을 강조한 방법론을 발표했다. 1990년대 중반부터 지금까지 발표된 다양한 애자일 개발 방법(methods)이다. DSDM(Dynamic Systems Development Methods, 1994) 스크럼(Scrum, 1995) 크리스털 방법..
Chapter 1. 전통적 프로젝트 경영에서 벗어나기 기존 프로젝트 관리의 문제점과 이슈를 제기하면서 이에 대한 해법을 애자일 관점에서 제시 1.1 업무 범위, 일정, 비용은 반드시 지켜야 하는가? [문제 의식] 어떤 프로젝트가 초기에 설정한 업무 범위와 일정, 비용은 모두 준수했지만 시장에서 별로 가치가 없는 제품을 만들거나 조직에서 아무도 사용하지 않는 시스템을 만든다면 이 프로젝트를 성공했다고 할 수 있을까? 고객 만족도나 시장 반응은 좋았지만 초기에 설정한 일정이나 비용을 정확히 지키지 못했다면 이 프로젝트는 실패한 것인가? [제언] 프로젝트에서 업무 범위, 일정, 비용을 관리하는 것은 매우 중요하지만 초기에 정한 목표를 무조건 준수하라는 의미는 아니다. 시장 및 고객에게 무엇이 가치가 있는지에 따라 신축성 있게 조정하는 것이 필요하다. [이유] 프..
자바 ORM 표준 JPA 프로그래밍 _ 기본(김영한) _ JPQL 소개, 문법 JPA는 다양한 쿼리 방법을 지원한다 JPQL JPA Criteria (자바코드로 JPQL 작성. 복잡하고 실용성X. QueryDSL 사용 권장) QueryDSL (자바코드로 JPQL 작성. JPQL 빌더 역할. 동적 쿼리 작성 편리함) 네이티브 SQL (JPA가 제공하는 SQL을 직접 사용. JPQL로 해결할 수 없는 특정 DB에 의존적인 기능 사용) JDBC API 직접 사용, MyBatis, SpringJdbcTemplate 함께 사용 (영속성 컨텍스트를 적절한 시점에 플러시 해야함) JPQL(Java Persistence Query Language) JPA를 사용하면 엔티티 객체를 중심으로 개발 검색을 할 때도 테이블이 아닌 엔티티 객체를 대상으로 검색 모든 DB 데이터를 객체로 변환해서 검색하는..
자바 ORM 표준 JPA 프로그래밍 - 기본(김영한) _ 값 타입 JPA의 데이터 타입 분류 엔티티 타입 @Entity로 정의하는 객체 데이터가 변해도 식별자(pk)로 지속해서 추적 가능 값 타입 int, Integer, String처럼 단순히 값으로 사용하는 자바 기본 타입이나 객체 식별자가 없고 값만 있으므로 변경 시 추적 불가 예시) int a = 100; a = 200; 하면 완전히 다른 값으로 대체됨 값 타입 분류 기본값 타입 자바 기본 타입(int, double) wrapper 클래스(Integer, Long) String 임베디드 타입(embedded type, 복합 값 타입) 컬렉션 값 타입(collection value type) 기본값 타입 예시) String name, int age 생명주기를 엔티티에 의존함 (예시: 회원을 삭제하면 이름, 나이 필..