가변인수
가변인수는 명시한 타입의 인수를 0개 이상 받을 수 있다. 가변인수 메서드를 호출하면, 가장 먼저 인수의 개수와 길이가 같은 배열을 만들고 인수들을 이 배열에 젖아하여 가변인수 메서드에 건네준다.
인수가 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개만 넣어 호출하면 런타임에 실패한다.
- 코드가 지저분한다
- args 유효성 검사를 명시적으로 해야 한다.
이를 다음코드처럼 매개변수를 2개 받도록 하면 매끄럽게 해결된다.
static int min(int firstArg, int... remainingArgs) {
int min = firstArg;
for (int arg : remainingArgs)
if (arg < min)
min = arg;
return min;
}
가변인수와 성능
만약 성능에 민감한 상황이라면 가변인수가 걸림돌이 될 수 있다. 가변인수 메서드는 호출될 때마다 배열을 새로 하나 할당하고 초기화한다. 이럴 때는 메서드 호출의 빈도수를 고려하여 메서드를 작성하면 된다.
예를 들어 해당 메서드 호출의 95%가 인수를 3개 이하로 사용한다고 해보자. 그렇다면 인수가 0개인 것부터 4개인 것까지 총 5개를 다중정의하자. 마지막 다중정의 메서드가 인수 4개 이상인 5%의 호출을 담당한다.
public void food() {}
public void food(int a1) {}
public void food(int a1, int a2) {}
public void food(int a1, int a2, int a3) {}
public void food(int a1, int a2, int a3, int... rest) {}