Coding i came around to check for the vararg performance of Java.
I write following test code:
public class T {
public static void main(String[] args) {
int n = 100000000;
String s1 = new String("");
String s2 = new String("");
String s3 = new String("");
String s4 = new String("");
String s5 = new String("");
long t = System.currentTimeMillis();
for (int i = 0; i < n; i++) {
foo();
}
System.err.println(System.currentTimeMillis() - t);
t = System.currentTimeMillis();
for (int i = 0; i < n; i++) {
baz(s1, s2, s3, s4, s5);
}
System.err.println(System.currentTimeMillis() - t);
t = System.currentTimeMillis();
for (int i = 0; i < n; i++) {
bar(s1, s2, s3, s4, s5);
}
System.err.println(System.currentTimeMillis() - t);
}
static void foo() {
}
static void bar(String a1, String a2, String a3, String a4, String a5) {
}
static void baz(String... a) {
}
}
On my machine the average output is:
78
4696
78
Seems that pass variables to methods is at no cost ?! Good !
But using varags is 60x slower ! Why ?
An explanation could be that the program must create the array on the heap and the time is spend by GC. But for less loops i still get as output:
0
62
0
What is spending this extra time for and anyway the compiler has all information to resolve this to a fix variable call ...
Its not my intention to optimize for that, but i found this curious ...
Update
I added a new test
t = System.currentTimeMillis();
for (int i = 0; i < n; i++) {
baz(s1);
}
System.err.println(System.currentTimeMillis() - t);
And this one argument version is still 30x slower. Maybe there is an ArrayList.toArray() behind the scene ?
So be aware of no-needed varags methods in your code and refactor to fix length. That could be a perfomance boost.
Varargs are useful for any method that needs to deal with an indeterminate number of objects. One good example is String. format . The format string can accept any number of parameters, so you need a mechanism to pass in any number of objects.
Rules for varargs:There can be only one variable argument in the method. Variable argument (varargs) must be the last argument.
Syntax of Varargs A variable-length argument is specified by three periods or dots(…). This syntax tells the compiler that fun( ) can be called with zero or more arguments.
13) How many maximum numbers of Varargs or Variable-Arguments can be there in a method or a constructor in Java? Explanation: Yes, only one.
Static list of arguments is quite different from an array. When you pass them that way, compiler reserves space for the references and populates them when the method is called.
Varargs is an equivalent of array. To call such a method, it's necessary to create and populate array at run time. That's why you observe the difference.
String[]
and String...
are synonyms. If you compared them, you should see identical performance.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With