Study

Study/이펙티브 자바

[Effective Java 3E] 추상 클래스보다는 인터페이스를 우선하라

💥 개요 자바에서 제공하는 다중 구현 메커니즘은 인터페이스와 추상 클래스, 이렇게 두가지 입니다. JAVA 8부터 인터페이스도 default method를 제공할 수 있게 되어, 현재 두 방법 모두 인스턴스 메서드를 구현 형태로 제공할 수 있게 되었습니다. 둘의 가장 큰 차이는 추상 클래스가 정의한 타입을 구현하는 클래스는 반드시 추상 클래스의 하위 클래스가 되어야 한다는 점 입니다. 자바는 단일 상속만 지원하니, 추상 클래스 방식은 새로운 타입을 정의하는데 커다란 제약이 있습니다. 반면 인터페이스가 선언한 메서드를 모두 정의하고 그 일반 규약을 잘 지킨 클래스라면 다른 어떤 클래스를 상속했든 같은 타입으로 취급합니다. 🔍 인터페이스를 사용해야 하는 이유 기존 클래스에도 손쉽게 새로운 인터페이스를 구현해..

Study/이펙티브 자바

[Effective Java 3E] 상속을 고려해 설계하고 문서화하라. 그러지 않았다면 상속을 금지하라

💥 개요 메서드를 재정의하면 어떤 일이 일어나는지를 정확히 정리하여 문서로 남겨야 합니다. 상속용 클래스는 재정의할 수 있는 메서드들을 내부적으로 어떻게 이용하는지(자기사용) 문서로 남겨야 합니다. 클래스의 API로 공개된 메서드에서 클래스 자신의 또 다른 메서드를 호출할 수도 있씁니다. 그런데 마침 호출되는 메서드가 재정의 가능 메서드라면 그 사실을 호출하는 메서드의 API 설명에 적시해야 합니다. 어떤 순서로 호출하는지, 각각의 호출 결과가 이어지는 처리에 어떤 영향을 주는지도 담아야 합니다. 즉 모든 상황을 문서로 남겨야 합니다. 상속이 캡슐화를 해친다. API문서 메서드 설명 끝에 종종 "Implementation Requirements"로 시작하는 절을 볼 수 있는데 내부 동작방식을 설명하는 곳..

Study/이펙티브 자바

[Effective Java 3E] 상속보다는 컴포지션을 사용하라

💥 개요 상속은 코드를 재사용하는 강력한 수단이지만, 항상 최선은 아닙니다. 패키지 안에서라면 상속도 안전하지만 잘못 사용하면 오류를 내기 쉬운 소프트웨어를 만들게 됩니다. 메서드 호출과 달리 상속은 캡슐화를 깨뜨린다. 상위 클래스가 어떻게 구현되느냐에 따라 하위 클래스의 동작에 이상이 생길 수 있습니다. 상위 클래스는 내부 구현이 달라지게 되면 하위 클래스에 이상이 생길 수 있습니다. HashSet을 사용하는 프로그램이 있고, 성능을 높이려면 이 HashSet은 처음 생성된 이후 몇개의 원소가 더해졌는지 알 수 있어야 한다고 가정하여 아래 코드와 같이 변수와 접근자 메서드를 추가하고 add와 addAll을 재정의 한 경우를 확인해 보겠습니다. // 코드 18-1 잘못된 예 - 상속을 잘못 사용했다! (..

Study/이펙티브 자바

[Effective Java 3E] 변경 가능성을 최소화하라

💥 개요 불변클래스란 인스턴스 내부 값을 수정할 수 없는 클래스다. 불변 인스턴스에 간직된 정보는 생성된 순간부터 파괴되는 순간까지 절대 달라지지 않습니다. 자바에서 String, 기본 타입의 박싱된 클래스, BigInteger, BigDecimal이 여기에 속합니다. 📃 불변 클래스를 만드는 5가지 규칙 객체의 상태를 변경하는 메서드(변경자)를 제공하지 않는다. 클래스를 확장할 수 없도록 한다. (상속한 클래스에서 객체의 상태를 변하게 만드는 상태를 막아줌, 대표적인 방법으로 final Class) 모든 필드를 final로 선언한다. 모든 필드를 private으로 선언한다. 자신 외에는 내부의 가변 컴포넌트에 접근할 수 없도록 한다. 👍대표적인 불변 클래스 public final class Comple..

Study/이펙티브 자바

[Effective Java 3E] public 클래스에서는 public 필드가 아닌 접근자 메서드를 사용하라

💥 개요 이따금 인스턴스 필드들을 모아놓는 일 외에는 아무 목적도 없는 퇴보한 클래스를 작성하려 할 때가 있습니다. class Point { public double x; public double y; } 이런 클래스는 데이터 필드에 직접 접근할 수 있으니 캡슐화의 이점을 제공하지 못합니다. API를 수정하지 않고 내부 표현을 바꿀 수 없고, 불변식을 보장할 수 없으며, 외부에서 필드에 접근할 때 부수 작업을 수행할 수도 없습니다. 철저한 객체 지향 프로그래머는 이런 클래스를 싫어해 모두 private으로 필드를 변경하고 public 접근자(getter)를 추가합니다. class Point { private double x; private double y; public Point(double x, dou..

Study/이펙티브 자바

[Effective Java 3E] 클래스와 멤버의 접근 권한을 최소화하라

💥 개요 잘 설계된 컴포넌트는 클래스 내부 데이터와 내부 구현 정보를 얼마나 잘 숨겼느냐 입니다. 잘 설계된 컴포넌트는 모든 내부 구현을 완벽히 숨겨, 구현과 API를 깔끔히 분리합니다. 오직 API만을 통해 다른 컴포넌트와 소통하며 서로의 내부 동작 방식에는 전혀 영향을 끼치지 않는데 이것을 정보 은닉, 혹은 캡슐화라고 합니다. ( 소프트웨어 설계의 근간이 되는 원리) 👍 정보 은닉의 장점 정보 은닉의 장점은 정말 많습니다. 그중 대부분은 컴포넌트를 서로 독립시켜서 개발, 테스트, 최적화, 적용, 분석, 수정을 개별적으로 할 수 있게 해주는 것과 연관이 되어있습니다. 시스템 개발 속도를 높인다. 각 컴포넌트를 병렬로 개발이 가능 시스템 관리 비용을 낮춘다. 작은 컴포넌트로 나눠 빨리 파악할 수 있고 디..

Study/이펙티브 자바

[Effective Java 3E] Comparable을 구현할지 고민하라

💥 개요 compareTo는 equals, hashcode, toString과 다르게 Object의 메서드가 아닙니다. 그리고 equals와 2가지만 제외하면 거의 비슷한데, compreTo는 동치성 비교에 더해 순서까지 비교할 수 있으며, 제네릭합니다. 즉 Compareble을 구현하게 된다면 그 클래스의 인스턴스에는 자연적인 순서가 있음을 뜻합니다. 그래서 Compareble을 구현한 객체의 배열은 Arrays.sort(a)와 같이 손쉽게 정렬이 가능합니다. public class WordList { public static void main(String[] args) { Set s = new TreeSet(); Collections.addAll(s, args); System.out.println(s..

Study/이펙티브 자바

[Effective Java 3E] clone 재정의는 주의해서 진행하라

💥 개요 Coneable은 복제해도 되는 클래스임을 명시하는 용도의 믹스인 인터페이스지만, 아쉽게 목적을 제대로 이루지 못했습니다. 가장 큰 문제는 clone 메서드가 Object에 선언되어있고 protected로 정의되어 있다는 점 입니다. 그래서 Cloneable을 구현하는 것 만으로 외부에서 clone 메서드를 호출할 수 없습니다. Cloneable 인터페이스는 Object의 protected clone의 동작방식을 결정합니다. Cloneable을 구현한 클래스에서 clone을 호출하면 그 객체를 복사한 객체를 반환하며, 그렇지 않은 클래스라면 CloneNotSupportedException을 던지게 됩니다. Cloneable을 구현한 클래스의 clone은 public으로 제공하며, 사용자는 복제가..

mntdev
'Study' 카테고리의 글 목록 (5 Page)