2016-08-18 11:05:53 -06:00
|
|
|
// understandingcollections/jmh/Lists.java
|
2016-08-09 10:21:47 -06:00
|
|
|
// (c)2016 MindView LLC: see Copyright.txt
|
|
|
|
// We make no guarantees that this code is fit for any purpose.
|
2016-09-23 13:23:35 -06:00
|
|
|
// Visit http://OnJava8.com for more book information.
|
2016-10-22 13:35:19 -07:00
|
|
|
// Performance differences between Lists
|
2016-08-18 11:05:53 -06:00
|
|
|
package understandingcollections.jmh;
|
2016-08-09 10:21:47 -06:00
|
|
|
import org.openjdk.jmh.annotations.*;
|
|
|
|
import org.openjdk.jmh.infra.Blackhole;
|
|
|
|
import java.util.*;
|
2016-10-22 13:35:19 -07:00
|
|
|
import java.util.concurrent.*;
|
2016-08-09 10:21:47 -06:00
|
|
|
|
|
|
|
@State(Scope.Thread)
|
2016-10-22 13:35:19 -07:00
|
|
|
@OutputTimeUnit(TimeUnit.MICROSECONDS)
|
|
|
|
@Warmup(iterations = 5, batchSize = 5000)
|
|
|
|
@Measurement(iterations = 5, batchSize = 5000)
|
|
|
|
@BenchmarkMode(Mode.SingleShotTime)
|
2016-08-09 10:21:47 -06:00
|
|
|
@Fork(1)
|
|
|
|
public class Lists {
|
2016-10-22 13:35:19 -07:00
|
|
|
private List<String> list;
|
2016-08-09 10:21:47 -06:00
|
|
|
|
2016-10-22 13:35:19 -07:00
|
|
|
@Param({
|
|
|
|
"java.util.ArrayList",
|
|
|
|
"java.util.Vector",
|
|
|
|
"java.util.LinkedList",
|
|
|
|
"java.util.concurrent.CopyOnWriteArrayList"
|
|
|
|
})
|
2016-08-09 10:21:47 -06:00
|
|
|
private String type;
|
|
|
|
|
2016-10-22 13:35:19 -07:00
|
|
|
@Param({
|
|
|
|
"1",
|
|
|
|
"10",
|
|
|
|
"100",
|
|
|
|
"1000",
|
|
|
|
"10000",
|
|
|
|
"100000"
|
|
|
|
})
|
|
|
|
private int size;
|
2016-08-09 10:21:47 -06:00
|
|
|
|
|
|
|
@Setup
|
|
|
|
public void setup() {
|
2016-10-22 13:35:19 -07:00
|
|
|
try {
|
|
|
|
list = (List<String>)
|
|
|
|
Class.forName(type).newInstance();
|
|
|
|
} catch(Exception e) {
|
|
|
|
System.err.println(
|
|
|
|
"-> Cannot create: " + type);
|
|
|
|
System.exit(99);
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
2016-10-22 13:35:19 -07:00
|
|
|
for(int i = 0; i < size; i++)
|
|
|
|
list.add(Integer.toString(i));
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
|
|
|
@Benchmark
|
2016-10-22 13:35:19 -07:00
|
|
|
public List<String> add() {
|
|
|
|
list.add(list.size() / 2, "test");
|
|
|
|
return list;
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
|
|
|
@Benchmark
|
|
|
|
public void get(Blackhole bh) {
|
2016-10-22 13:35:19 -07:00
|
|
|
bh.consume(list.get(list.size() / 2));
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
|
|
|
@Benchmark
|
2016-10-22 13:35:19 -07:00
|
|
|
public List<String> set() {
|
|
|
|
list.set(list.size() / 2, "test");
|
|
|
|
return list;
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
|
|
|
@Benchmark
|
2016-10-22 13:35:19 -07:00
|
|
|
public List<String> iteradd() {
|
|
|
|
ListIterator<String> it =
|
|
|
|
list.listIterator(list.size() / 2);
|
|
|
|
try {
|
|
|
|
it.add("test");
|
|
|
|
} catch(UnsupportedOperationException e) {
|
|
|
|
System.err.println(
|
|
|
|
"-> Unsupported: listIterator.add() in " +
|
|
|
|
list.getClass().getSimpleName());
|
|
|
|
}
|
|
|
|
return list;
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
|
|
|
@Benchmark
|
2016-10-22 13:35:19 -07:00
|
|
|
public List<String> insert() {
|
|
|
|
list.add(list.size() / 2, "test");
|
|
|
|
return list;
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
|
|
|
@Benchmark
|
2016-10-22 13:35:19 -07:00
|
|
|
public List<String> remove() {
|
|
|
|
int index = list.size() / 2;
|
|
|
|
if(index > 0)
|
|
|
|
list.remove(index);
|
|
|
|
return list;
|
2016-08-09 10:21:47 -06:00
|
|
|
}
|
|
|
|
}
|