// understandingcollections/jmh/Queues.java // (c)2016 MindView LLC: see Copyright.txt // We make no guarantees that this code is fit for any purpose. // Visit http://OnJava8.com for more book information. // Performance differences between Queues package understandingcollections.jmh; import org.openjdk.jmh.annotations.*; import org.openjdk.jmh.infra.Blackhole; import java.util.*; import java.util.concurrent.*; @State(Scope.Thread) @OutputTimeUnit(TimeUnit.MICROSECONDS) @Warmup(iterations = 5, batchSize = 5000) @Measurement(iterations = 5, batchSize = 5000) @BenchmarkMode(Mode.SingleShotTime) @Fork(1) public class Queues { private Queue queue; @Param({ "java.util.LinkedList", "java.util.concurrent.ConcurrentLinkedQueue", "java.util.concurrent.LinkedBlockingQueue", "java.util.concurrent.LinkedTransferQueue", "java.util.concurrent.PriorityBlockingQueue", "java.util.PriorityQueue", // Requires a size for construction: //"java.util.concurrent.ArrayBlockingQueue", // Won't accept more than one element: //"java.util.concurrent.SynchronousQueue", // Requires "Delayed" elements: //"java.util.concurrent.DelayQueue", }) private String type; @Param({ "1", "10", "100", "1000", "10000", "100000" }) private int size; @Setup public void setup() { try { queue = (Queue) Class.forName(type).newInstance(); } catch(Exception e) { System.err.println( "-> Cannot create: " + type); System.exit(99); } for(int i = 0; i < size; i++) queue.add(Integer.toString(i)); } @Benchmark public Queue add() { queue.add("test"); return queue; } @Benchmark public void poll(Blackhole bh) { bh.consume(queue.poll()); } }