OnJava8-Examples/collectionsindepth/ListPerformance.java

212 lines
6.7 KiB
Java
Raw Normal View History

2015-12-15 11:47:04 -08:00
// collectionsindepth/ListPerformance.java
// (c)2016 MindView LLC: see Copyright.txt
2015-11-15 15:51:35 -08:00
// We make no guarantees that this code is fit for any purpose.
// Visit http://mindviewinc.com/Books/OnJava/ for more book information.
2016-01-25 18:05:55 -08:00
// Demonstrates performance differences in Lists
2016-07-07 12:43:10 -06:00
// Small to keep build testing short:
// {Args: 100 500}
2015-06-15 17:47:35 -07:00
import java.util.*;
import onjava.*;
2015-06-15 17:47:35 -07:00
public class ListPerformance {
2016-01-25 18:05:55 -08:00
static SplittableRandom rand = new SplittableRandom();
2015-06-15 17:47:35 -07:00
static int reps = 1000;
static List<Test<List<Integer>>> tests =
new ArrayList<>();
static List<Test<LinkedList<Integer>>> qTests =
new ArrayList<>();
static {
tests.add(new Test<List<Integer>>("add") {
@Override
int test(List<Integer> list, TestParam tp) {
int loops = tp.loops;
int listSize = tp.size;
for(int i = 0; i < loops; i++) {
list.clear();
for(int j = 0; j < listSize; j++)
list.add(j);
}
return loops * listSize;
}
});
tests.add(new Test<List<Integer>>("get") {
@Override
int test(List<Integer> list, TestParam tp) {
int loops = tp.loops * reps;
int listSize = list.size();
for(int i = 0; i < loops; i++)
list.get(rand.nextInt(listSize));
return loops;
}
});
tests.add(new Test<List<Integer>>("set") {
@Override
int test(List<Integer> list, TestParam tp) {
int loops = tp.loops * reps;
int listSize = list.size();
for(int i = 0; i < loops; i++)
list.set(rand.nextInt(listSize), 47);
return loops;
}
});
tests.add(new Test<List<Integer>>("iteradd") {
@Override
int test(List<Integer> list, TestParam tp) {
final int LOOPS = 1000000;
int half = list.size() / 2;
2016-01-25 18:05:55 -08:00
ListIterator<Integer> it =
list.listIterator(half);
2015-06-15 17:47:35 -07:00
for(int i = 0; i < LOOPS; i++)
it.add(47);
return LOOPS;
}
});
tests.add(new Test<List<Integer>>("insert") {
@Override
int test(List<Integer> list, TestParam tp) {
int loops = tp.loops;
for(int i = 0; i < loops; i++)
list.add(5, 47); // Minimize random-access cost
return loops;
}
});
tests.add(new Test<List<Integer>>("remove") {
@Override
int test(List<Integer> list, TestParam tp) {
int loops = tp.loops;
int size = tp.size;
for(int i = 0; i < loops; i++) {
list.clear();
list.addAll(new CountingIntegerList(size));
while(list.size() > 5)
list.remove(5); // Minimize random-access cost
}
return loops * size;
}
});
// Tests for queue behavior:
qTests.add(new Test<LinkedList<Integer>>("addFirst") {
@Override
int test(LinkedList<Integer> list, TestParam tp) {
int loops = tp.loops;
int size = tp.size;
for(int i = 0; i < loops; i++) {
list.clear();
for(int j = 0; j < size; j++)
list.addFirst(47);
}
return loops * size;
}
});
qTests.add(new Test<LinkedList<Integer>>("addLast") {
@Override
int test(LinkedList<Integer> list, TestParam tp) {
int loops = tp.loops;
int size = tp.size;
for(int i = 0; i < loops; i++) {
list.clear();
for(int j = 0; j < size; j++)
list.addLast(47);
}
return loops * size;
}
});
qTests.add(
new Test<LinkedList<Integer>>("rmFirst") {
@Override
int test(LinkedList<Integer> list, TestParam tp) {
int loops = tp.loops;
int size = tp.size;
for(int i = 0; i < loops; i++) {
list.clear();
list.addAll(new CountingIntegerList(size));
while(list.size() > 0)
list.removeFirst();
}
return loops * size;
}
});
qTests.add(new Test<LinkedList<Integer>>("rmLast") {
@Override
int test(LinkedList<Integer> list, TestParam tp) {
int loops = tp.loops;
int size = tp.size;
for(int i = 0; i < loops; i++) {
list.clear();
list.addAll(new CountingIntegerList(size));
while(list.size() > 0)
list.removeLast();
}
return loops * size;
}
});
}
static class ListTester extends Tester<List<Integer>> {
2015-12-15 11:47:04 -08:00
public ListTester(List<Integer> collection,
2015-06-15 17:47:35 -07:00
List<Test<List<Integer>>> tests) {
2015-12-15 11:47:04 -08:00
super(collection, tests);
2015-06-15 17:47:35 -07:00
}
// Fill to the appropriate size before each test:
2016-01-25 18:05:55 -08:00
@Override
protected List<Integer> initialize(int size) {
2015-12-15 11:47:04 -08:00
collection.clear();
collection.addAll(new CountingIntegerList(size));
return collection;
2015-06-15 17:47:35 -07:00
}
// Convenience method:
public static void run(List<Integer> list,
List<Test<List<Integer>>> tests) {
new ListTester(list, tests).timedTest();
}
}
public static void main(String[] args) {
if(args.length > 0)
Tester.defaultParams = TestParam.array(args);
// Can only do these two tests on an array:
Tester<List<Integer>> arrayTest =
2016-01-25 18:05:55 -08:00
new Tester<List<Integer>>(null,
tests.subList(1, 3)) {
2015-06-15 17:47:35 -07:00
// This is called before each test. It
// produces a non-resizeable array-backed list:
@Override protected
List<Integer> initialize(int size) {
2016-01-25 18:05:55 -08:00
Integer[] ia = new Integer[size];
Arrays.setAll(ia, new Count.Integer()::get);
2015-06-15 17:47:35 -07:00
return Arrays.asList(ia);
}
};
arrayTest.setHeadline("Array as List");
arrayTest.timedTest();
Tester.defaultParams= TestParam.array(
10, 5000, 100, 5000, 1000, 1000, 10000, 200);
if(args.length > 0)
Tester.defaultParams = TestParam.array(args);
ListTester.run(new ArrayList<>(), tests);
ListTester.run(new LinkedList<>(), tests);
ListTester.run(new Vector<>(), tests);
Tester.fieldWidth = 12;
Tester<LinkedList<Integer>> qTest =
new Tester<LinkedList<Integer>>(
new LinkedList<>(), qTests);
qTest.setHeadline("Queue tests");
qTest.timedTest();
}
2015-09-07 11:44:36 -06:00
}
/* Output:
2015-06-15 17:47:35 -07:00
--- Array as List ---
2015-12-15 11:47:04 -08:00
size get set
100 19 20
2015-06-15 17:47:35 -07:00
--------------------- ArrayList ---------------------
2015-12-15 11:47:04 -08:00
size add get set iteradd insert remove
100 31 19 21 33 158 114
2015-06-15 17:47:35 -07:00
--------------------- LinkedList ---------------------
2015-12-15 11:47:04 -08:00
size add get set iteradd insert remove
100 30 44 45 77 143 56
2015-06-15 17:47:35 -07:00
----------------------- Vector -----------------------
2015-12-15 11:47:04 -08:00
size add get set iteradd insert remove
100 26 32 33 64 147 67
2015-06-15 17:47:35 -07:00
-------------------- Queue tests --------------------
2015-12-15 11:47:04 -08:00
size addFirst addLast rmFirst rmLast
100 33 71 102 135
2015-09-07 11:44:36 -06:00
*/