본문 바로가기
반응형

java24

알고리즘 - 이분매칭 N 개의 리스트 A와 N 개의 리스트 B 라는 두 개의 컬렉션이 주어집니다. 즉, 리스트 A와 B의 길이는 갖고 서로 다른 데이터를 갖습니다. 기능 구현의 목적은 A와 B에 있는 데이터가 각각 1:1 매칭을 이루도록 하는 것입니다. 간단한 예로 다음과 같이 있을 때 .. List aList = Arrays.asList("A", "B", "C", "D"); List bList = Arrays.asList("1", "2", "3", "4"); A-1, B-2, C-3, D-4 로 매칭을 시켜야 합니다. 즉, 매칭을 시킬 때 간선이 발생하지 않도록 해야 합니다. 이와 관련된 다양한 알고리즘이 있습니다. 최대 유량 알고리즘 디닉(Dinic's) 알고리즘 - O(V^2*E) 에드몬드 카프(Edmonds k.. 2020. 4. 24.
Effective Java : (16) 추상 클래스보다는 인터페이스를 우선적으로 ! 추상 클래스보다는 인터페이스를 우선하라 (아이템 20) 자바가 제공하는 다중 구현 메커니즘은 인터페이스와 추상 클래스 두 가지 입니다. 자바 8부터는 인터페이스도 default method를 제공하여 구현 형태를 제공할 수 있습니다. 이 둘의 가장 큰 차이는 추상 클래스가 정의한 타입을 구현하는 클래스는 반드시 추상 클래스의 하위 클래스가 되어야 한다는 점입니다. 자바는 단일 상속만 지원하니, 추상 클래스 방식은 새로운 타입을 정의하는 데 커다란 제약을 안게 되는 셈입니다. 기존 클래스에도 손쉽게 새로운 인터페이스를 구현해넣을 수 있습니다. Comparable, Iterable, AutoCloseable 인터페이스가 추가되었을 때 표준 라이브러리의 수많은 기존 클래스가 이 인터페이스들을 구현한 채 릴리스.. 2020. 4. 24.
Effective Java : (15) Composition 활용 상속 보다는 컴포지션을 사용하라 (아이템 18) 상속은 코드를 재사용하는 강력한 수단이지만 항상 최선은 아닙니다. 잘못 사용하면 오류를 내기 쉬운 소프트웨어를 만듭니다. 상위 클래스와 하위클래스를 모두 같은 프로그래머가 통제하는 패키지 안에서라면 상속도 안전한 방법입니다. 메소드 호출과 달리 상속은 캡슐화를 깨뜨립니다. 상위 클래스가 확장을 충분히 고려하고 문서화도 제대로 해두지 않으면 하위 클래스는 상위 클래스의 변화에 발맞춰 수정돼야만 합니다. public class InstrumentedHashSet extends HashSet { private int addCount = 0; ... @Override public boolean add(E e) { addCount ++; return super.ad.. 2020. 4. 24.
Effective Java : (14) Public 클래스의 접근자 메서드 Public 클래스에서는 Public 필드가 아닌 접근자 메서드를 사용하라 (아이템 16) 다음 코드는 어떤 단점이 존재할까 ? class Point { public double x; public double y; } 필드 x, y에 직접 접근할 수 있기 때문에 캡슐화의 이점을 제공받지 못하게 됩니다. API 수정하지 않고는 내부 표현을 바꿀 수 없음 불변식을 보장받지 못함 외부에서 필드에 접근할 때 부수 작업을 수행할 수 없음 따라서 각 필드를 private으로 선언하고 getter, setter를 활용하는 것이 일반적입니다. 하지만 package-private, private 클래스는 데이터 필드를 노출한다 해도 하등의 문제가 없습니다. 이 방식이 클래스 선언 면에서나 클라이언트 코드 면에서나 접근자.. 2020. 4. 24.
Effective Java : (13) 변경 가능성을 최소화한 클래스 설계 변경 가능성을 최소화하라 (아이템 17) 불변 클래스란 그 인스턴스의 내부 값을 수정할 수 없는 클래스를 말합니다. 예로 String, BigInteger, BigDecimal을 볼 수 있습니다. 불변 클래스는 가변 클래스보다 설계하고 구현하고 사용하기 쉽고, 오류가 생길 여지도 적어 훨씬 안전합니다. 클래스를 불변으로 만들려면 다음 다섯 가지 규칙을 따르면 됩니다. 1. 객체의 상태를 변경하는 메서드(변경자)를 제공하지 않습니다. 2. 클래스를 확장할 수 없도록 합니다. 상속을 받는 대표적인 방법은 클래스를 final로 선언하는 것이지만 다른 방법도 알아보겠습니다. 3. 모든 필드를 final로 선언합니다. 새로 생성된 인스턴스를 동기화 없이 다른 스레드로 건네도 문제없이 동작하게끔 보장하는데 필요합니.. 2020. 4. 24.
Effective Java : (12) try-with-resource 사용 try-finally 보다는 try-with-resource를 사용하라 자바 라이브러리는 close 메서드를 호출해 직접 닫아줘야 하는 자원이 많습니다. 안전망으로 finalize가 있지만 많은 문제가 있기 때문에 썩 좋지 않습니다. 전통적으로는 try-finally를 많이 사용하였습니다. static String readLine(String path) throws IOException { BufferedReader br = new BufferedReader(new FileReader(path)); try { return br.readLine(); } finally { br.close(); } } 하지만 자원을 하나 더 사용하게 되면 코드가 지저분하게 되고, close를 놓치기도 합니다. static v.. 2020. 4. 24.
반응형