- 생성자 대신 정적 팩토리 메서드를 고려하라 - 현재
- 생성자에 매개변수가 많다면 빌더를 고려하라 - 현재
- private 생성자나 열거 타입으로 싱글턴을 보증하라 - 장우
- 인스턴스화를 막으려거든 private 생성자를 사용하라 - 민우
- 자원을 직접 명시하지 말고 의존 객체 주입을 사용하라 - 민우
- 불필요한 객체 생성을 피하라 - 장우
- 다 쓴 객체 참조를 해제하라 - 현재
- finalizer와 cleaner 사용을 피하라 - 장우
- try-finally보다는 try-with-resources를 사용하라 - 민우
- equals는 일반 규약을 지켜 재정의하라 - 민우
- equals를 재정의하면 hashCode도 재정의하라 - 장우
- toString을 항상 재정의하라 - 현재
- clone 재정의는 주의해서 진행하라 - 장우
- Comparable을 구현할지 고려하라- 현재
- 클래스와 멤버의 접근 권한을 최소화하라 - 민우
- public 클래스에는 public 필드 대신 접근자 메서드를 사용하라 - 장우
- 변경 가능성을 최소화하라 - 민우
- 상속보다는 컴포지션을 사용하라 - 현재
- 상속을 고려해 설계하고 문서화하라. 그렇지 않았다면 상속을 금지하라 - 민우
- 추상 클래스보다 인터페이스를 우선하라 - 장우
- 인터페이스는 구현하는 쪽을 생각해 설계하라 - 현재
- 인터페이스는 타입을 정의하는 용도로만 사용하라 - 민우
- 태그 달린 클래스보다 클래스 계층구조를 사용하라 - 장우
- 멤버 클래스는 되도록 static으로 만들라 - 현재
- 톱레벨 클래스는 한 파일에 하나만 담아라 - 장우
- 로 타입은 사용하지말라 - 민우
- 비검사 경고를 제거하라 - 현재
- 배열보다 리스트를 사용하라 - 민우
- 이왕이면 제네릭 타입으로 만들라 - 장우
- 이왕이면 제네릭 메서드로 만들라 - 현재
- 한정적 와일드카드로 API 유연성을 높여라 - 장우
- 제네릭과 가변인수는 함께 쓸 때 신중하라 - 현재
- 타입 안전 이종 컨테이너를 고려하라 - 민우
- int 상수 대신 열거 타입을 사용하라 - 장우
- ordinal 메서드 대신 인스턴스 필드를 사용하라 - 민우
- 비트 필드 대신 EnumSet을 사용하라 - 현재
- ordinal 인덱싱 대신 EnumMap을 사용하라 - 장우
- 확장할 수 있는 열거 타입이 필요하면 인터페이스를 사용하라 - 민우
- 명명 패턴보다 애노테이션을 사용하라 -현재
- @Override 애너테이션을 일관되게 사용하라 - 민우
- 정의하려는 것이 타입이면 마커 인터페이스를 사용하라 - 장우
- 익명 클래스보다 람다를 사용하라 - 현재
- 람다보다 메서드 참조를 사용하라 - 현재
- 표준 함수형 인터페이스를 사용하라 - 장우
- 스트림은 주의해서 사용하라 - 민우
- 스트림에서는 부작용 없는 함수를 사용하라 - 현재
- 반환 타입으로는 스트림보다 컬렉션이 낫다 - 장우
- 스트림 병렬화는 주의해서 적용하라 - 민우
- 매개변수 유효성을 검사하라
- 적시에 방어적 복사본을 만들라
- 메서드 시그니처를 신중히 설계하라
- 다중정의는 신중히 사용하라
- 가변인수는 신중히 사용하라
- null이 아닌, 빈 컬렉션이나 배열을 반환하라
- 옵셔널 반환은 신중히 하라
- 공개 API 요소에는 항상 문서화 주석을 작성하라
- 지역변수의 범위를 최소화하라
- 전통적인 for 문보다 for-each 문을 사용하라
- 라이브러리를 익히고 사용하라
- 정확한 계산에는 float와 double을 피하라
- 박싱된 기본 타입보다 기본 타입을 사용하라
- 다른 타입이 적절하다면 문자열 사용을 피하라
- 문자열 연결은 느리니 주의하라
- 객체는 인터페이스로 참조하라
- 리플렉션보다 인터페이스를 사용하라
- 네이티브 메서드는 신중히 사용하라
- 최적화는 신중히 하라
- 일반적으로 통용되는 명명 규칙을 따르라
- 예외는 진짜 예외 상황에만 사용하라
- 복구 가능한 상황엔 검사 예외를, 프로그래밍 오류엔 런타임 예외를 사용하라
- 불필요한 검사 예외 사용을 피하라
- 표준 예외를 사용하라
- 추상화 수준에 맞는 예외를 던져라
- 메서드가 던지는 모든 예외를 문서화하라
- 예외 메시지에 실패 관련 정보를 담아라
- 가능한 한 실패 원자적으로 만들라
- 예외를 무시하지 말라
- 공유 중인 가변 데이터는 동기화해 사용하라
- 과도한 동기화는 피하라
- 스레드보다 실행자, 태스크, 스트림을 애용하라
- wait와 notify보다 동시성 유틸리티를 애용하라
- 스레드 안전성 수준을 문서화하라
- 지연 초기화는 신중히 사용하라
- 프로그램 동작을 스레드 스케줄러에 기대지 말라
- 자바 직렬화의 대안을 찾으라
- Serializable 구현 여부를 신중히 결정하라
- 커스텀 직렬화 형태를 고려하라
- readObject 메서드는 방어적으로 작성하라
- 인스턴스 수를 통제해야 한다면 readResolve보다 열거 타입을 사용하라
- 직렬화된 인스턴스 대신 직렬화 프록시 사용을 검토하라
-
본인이 정리한 부분은 본인의 이름 브랜치에 기록한다.
- 브랜치는 영어(소문자)로 설정
main(default) choijangwoo yukminwoo kimjaehyun kimhyunjae -
각 주차 세미나 부분의 개인 링크를 수정할 때는 main에서 브랜치를 분기하여 readme를 수정 후 PR을 작성한 뒤 분기한 브랜치를 삭제한다.
- 담당한 아이템의 부분을 다음과 같이 수정한다.
[item명 - 이름](readme 링크)
![]() |
![]() |
![]() |
|---|---|---|
| 최장우 @choijw1004 |
육민우 @minwoo_Yuk |
김현재 @Kguswo |


