1   /**
2    * Logback: the reliable, generic, fast and flexible logging framework.
3    * Copyright (C) 1999-2015, QOS.ch. All rights reserved.
4    *
5    * This program and the accompanying materials are dual-licensed under
6    * either the terms of the Eclipse Public License v1.0 as published by
7    * the Eclipse Foundation
8    *
9    *   or (per the licensee's choosing)
10   *
11   * under the terms of the GNU Lesser General Public License version 2.1
12   * as published by the Free Software Foundation.
13   */
14  package ch.qos.logback.core.contention;
15  
16  import ch.qos.logback.core.testUtil.RunnableWithCounterAndDone;
17  
18  /**
19   * Useful scaffolding to measure the throughput of certain operations when
20   * invoked by multiple threads.
21   * 
22   * @author Joern Huxhorn
23   * @author Ralph Goers
24   * @author Ceki Gulcu
25   */
26  public class ThreadedThroughputCalculator extends MultiThreadedHarness {
27  
28      public ThreadedThroughputCalculator(long overallDurationInMillis) {
29          super(overallDurationInMillis);
30      }
31  
32      public void printThroughput(RunnableWithCounterAndDone[] runnableArray, String msg) throws InterruptedException {
33          printThroughput(runnableArray, msg, false);
34      }
35  
36      public void printThroughput( RunnableWithCounterAndDone[] runnableArray, String msg, boolean detailed) throws InterruptedException {
37          long sum = 0;
38          for (RunnableWithCounterAndDone r : runnableArray) {
39              if (detailed) {
40                  System.out.println(r + " count=" + r.getCounter());
41              }
42              sum += r.getCounter();
43          }
44  
45          System.out.println(msg + "total of " + sum + " operations, or " + ((sum) / overallDurationInMillis)
46                  + " operations per millisecond");
47      }
48  }