가변인수(varargs) 메서드는 명시한 타입의 인수를 0개 이상 받을 수 있다. 가변인수 메서드를 호출하면 가장 먼저 인수의 개수와 길이가 같은 배열을 만들고 인수들을 이 배열에 저장하여 가변인수 메서드에 건내준다.
static int sum(int... args) {
int sum = 0;
for (int arg : args)
sum += arg;
return sum;
}
sum(1, 2, 3)
인수가 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 유효성 검사를 명시적으로 해야하고, min의 초깃값을 Integer.MAX_VALUE
로 설정하지 않고는 더 명료한 for-each문도 사용할 수 없다.
아래는 훨씬 나은 방법이다.
static int min(int firstArgs, int... remainingArgs) {
int min = firstArg;
for (int arg : remainingArgs)
if (arg < min)
min = arg;
return min;
}
위의 코드처럼 매개변수를 2개 받도록 하면 된다. 가변인수는 인수 개수가 정해지지 않았을 때 유용하다.
하지만 성능에 민감한 상황이라면 가변인수가 걸림돌이 될 수도 있다. 가변인수 메서드는 호출될 때마다 배열을 새로 하나 할당하고 초기화한다.
...
그래서 일반적으로 많이 쓰이는 개수까지는 다중정의를 하고, 그 이후는 가변인수를 사용하기도 한다.
EnumSet 역시 이 기법을 사용해 열거 타입 집합 생성 비용을 최소화한다.