From ed5ad940a99e7e6386caa85fd01588a64220fa22 Mon Sep 17 00:00:00 2001 From: Stefan Suhren Date: Wed, 5 Nov 2014 00:55:06 +0100 Subject: Assignment No.6 added first version --- .../fhswf/in/inf/java1/aufgabe6/ListBenchmark.java | 102 +++++++++++++++++++++ 1 file changed, 102 insertions(+) create mode 100644 src/de/fhswf/in/inf/java1/aufgabe6/ListBenchmark.java (limited to 'src/de/fhswf/in/inf/java1/aufgabe6/ListBenchmark.java') diff --git a/src/de/fhswf/in/inf/java1/aufgabe6/ListBenchmark.java b/src/de/fhswf/in/inf/java1/aufgabe6/ListBenchmark.java new file mode 100644 index 0000000..a98cdd6 --- /dev/null +++ b/src/de/fhswf/in/inf/java1/aufgabe6/ListBenchmark.java @@ -0,0 +1,102 @@ +/** + * + */ +package de.fhswf.in.inf.java1.aufgabe6; + +import java.util.List; +import java.util.Random; + +/** + * TODO Add comment here + * + * @author $Author: $ + * @version $Revision: $, $Date: $ UTC + */ +public final class ListBenchmark +{ + + private final Integer testObj = new Integer(214); + + /** + * Prevents instantiation of the utility class. + * + */ + private ListBenchmark() + { + } + + /** + * Starts a benchmark of different Lists and different test cases. + * + */ + public void startBenchmark() + { + + } + + /** + * TODO Add method comment here + * + * @param list + * @param times + * @return + */ + private long benchmarkAtBeginning(List list, int times) + { + long start = System.currentTimeMillis(); // Gets current time in µs + + for (int i = 0; i < times; i++) + { + list.add(0, testObj); + } + + return (System.currentTimeMillis() - start); // Returns runtime + } + + /** + * TODO Add method comment here + * + * @param list + * @param times + * @return + */ + private long benchmarkAtEnding(List list, int times) + { + long start = System.currentTimeMillis(); // Gets current time in µs + + for (int i = 0; i < times; i++) + { + list.add(testObj); + } + + return (System.currentTimeMillis() - start); // Returns runtime + } + + /** + * TODO Add method comment here + * + * @param list + * @param times + * @return + */ + private long benchmarkAtRandom(List list, int times) + { + + int[] randVal = new int[times]; + Random rand = new Random(); + + for (int i = 0; i < randVal.length; i++) + { + randVal[i] = rand.nextInt(list.size()+i+1); + } + + long start = System.currentTimeMillis(); // Gets current time in µs + + for (int i = 0; i < times; i++) + { + list.add(randVal[i], testObj); + } + + return (System.currentTimeMillis() - start); // Returns runtime + } +} -- cgit v1.2.3-70-g09d2