이번장의 핵심은...
인수 개수가 일정하지 않은 메서드를 정의해야 한다면 가변인수가 반드시 필요합니다
메서드를 정의할 때 필수 매개변수는 가변인수 앞에 두고, 가변인수를 사용할 때는 성능문제까지 고려합시다
가변인수 메서드
명시한 타입의 인수를 0개 이상 받을 수 있습니다
예제) 간단한 가변인수 활용 예
static int sum(int... args) {
int sum = 0;
for (int arg : args)
sum += arg;
return sum;
}
sum(1,2,3) -> 6
sum(0) -> 0
잘못 구현한 예) 인수가 1개 이상이어야 하는 가변인수 메서드
// 코드 53-2 인수가 1개 이상이어야 하는 가변인수 메서드 - 잘못 구현한 예!
static int min(int... args) {
if (args.length == 0)
throw new IllegalArgumentException("인수가 1개 이상 필요합니다.");
int min = args[0];
for (int i = 1; i < args.length; i++)
if (args[i] < min)
min = args[i];
return min;
}
인수가 0개만 받을 수 있도록 설계하는 건 좋지 않습니다
가장 심각한 건 인수를 0개만 넣어 호출하면 컴파일타임이 아닌 런타임에 실패한다는 점입니다
→ 코드도 지저분해집니다
훨씬 나은 방법은 매개변수를 2개 받도록 하면 됩니다
1. 평범한 매개변수
2. 가변인수
static int min(int firstArg, int... remainingArgs) {
int min = firstArg;
for (int arg : remainingArgs)
if (arg < min)
min = arg;
return min;
}
성능이 민감한 상황이면 가변인수가 걸림돌이 될 수 있습니다
가변인수 메서드는 호출될 때마다 배열을 새로 하나 할당하고 초기화합니다
이 비용을 감당할 수는 없지만, 가변인수의 유연성이 필요할 때 선택할 수 있는 멋진 패턴이 있습니다
ex) 해당 메서드 호출의 95%가 인수를 3개 이하로 사용한다고 해봅시다
→ 그러면 다음처럼 인수가 0~4개인 것까지 총 5개를 다중정의합니다
그리고 마지막 다중정의 메서드가 인수 4개 이상인 5%의 호출을 담당
public void foo() {}
public void foo(int a1) {}
public void foo(int a1, int a2) {}
public void foo(int a1, int a2, int a3) {}
public void foo(int a1, int a2, int a3, int... rest) {}
즉, 메서드 호출 중 단 5%만이 배열을 생성합니다
→ EnumSet의 정적 팩터리도 이 기법을 사용해 열거 타입 집합 생성 비용을 최소화할 수 있습니다
'Java > Effective Java 3E' 카테고리의 다른 글
[이펙티브자바 3판] ITEM55. 옵셔널 반환은 신중히 하라 (0) | 2021.01.16 |
---|---|
[이펙티브자바 3판] ITEM54. null이 아닌, 빈 컬렉션이나 배열을 반환하라 (0) | 2021.01.16 |
[이펙티브자바 3판] ITEM52. 다중정의는 신중히 사용하라 (2) | 2021.01.04 |
[이펙티브자바 3판] ITEM51. 메서드 시그니처를 신중히 설계하라 (0) | 2020.12.27 |
[이펙티브자바 3판] ITEM50. 적시에 방어적 복사본을 만들라 (0) | 2020.12.22 |
댓글