익명 클래스
Collections.sort(words, new Comparator<String>() {
public int compare(String s1, String s2) {
return Integer.compare(s1.length(), s2.length())
}
});
람다
Collections.sort(words,
(s1, s2) -> Integer.compare(s1.length(), s2.length())
);
- 람다는 함수나 익명 클래스와 개념은 비슷하지만 코드는 훨씬 간결하다.
람다를 사용할 때는 타입을 명시해야하는 코드가 더 명확할 때만 제외하고는, 람다의 모든 매개변수 타입은 생략하자.
- 람다 자리에 비교자 생성 메서드를 사용하면 코드를 더 간결하게 만들 수 있다.
Collections.sort(words, comparingInt(String::lenght));
- 자바 8 때 List 인터페이스에 추가된 sort 메서드를 이용하면 더 짧아진다.
words.sort(comparingInt(String::length));
- 람다를 사용하면 기존에 적합하지 않았던 곳에서도 함수 객체를 실용적으로 사용할 수 있다.
public enum Operation {
PLUS ("+", (x, y) -> x + y),
MINUS ("-", (x, y) -> x - y),
TIMES ("+", (x, y) -> x * y),
DIVIDE ("+", (x, y) -> x / y);
private final String symbol;
private final DoubleBinaryOperator op;
Operation(String symbol, DoubleBinaryOperator op) {
this.symbol = symbol;
this.op = op;
}
@Override public String toString() { return symbol; }
public double apply(double x, double y) {
return op.applyAsDouble(x,y);
}
}
- 람다를 사용하는 경우 코드 자체로 동작이 명확히 설명되지 않거나 코드 줄 수가 많아지면 람다를 쓰지 말아야 한다.
- 람다는 한줄일 때 가장 좋고 길어야 세 줄 안에 끝내는 게 좋다.
- 열거 타입 생성자 안의 람다는 열거 타입의 인스턴스 멤버에 접근할 수 없다. 따라서 상수별 동작을 단 몇줄로 구현하기 어렵거나, 인스턴스 필드나 메서드를 사용해야만 하는 상황이라면 상수별 클래스 몸체를 사용해야한다.
- 람다는 함수형 인터페이스에서만 쓰인다.
- 클래스의 인스턴스를 만들 때 람다를 쓸 수 없으니, 익명 클래스를 써야 한다.
- 람다는 자신을 참조할 수 없다. 람다에서의 this 키워드는 바깥 인스턴스를 가리킨다. 반면 익명 클래스에서의 this는 익명 클래스의 인스턴스 자신을 가리킨다. 함수 객체가 자신을 참조해야 한다면 반드시 익명 클래스를 써야 한다.
- 람다도 익명 클래스 처럼 직렬화 형태가 구현 별로 다를 수 있기에 람다를 직렬화하는 일은 극히 삼가야 한다. 정말 직렬화해야할 때는 private 정적 중첩 클래스의 인스턴스를 사용을 추천한다.
'Java > EffectiveJava' 카테고리의 다른 글
Effective Java Item41. 정의하려는 것이 타입이라면 마커 인터페이스를 사용하라. (0) | 2025.02.16 |
---|---|
Effective Java Item33. 타입 안전 이종 컨테이너를 고려하라. (0) | 2025.02.09 |
Effective Java Item32. 제네릭과 가변인수를 함께 쓸 때는 신중하라. (0) | 2025.02.09 |
Effective Java Item26. 로 타입은 사용하지 말라. (0) | 2025.01.24 |
Effective Java Item24. 멤버 클래스는 되도록 static으로 만들라. (0) | 2025.01.23 |