Skip to content

gperfutils/gprof

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

94 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OVERVIEW
--------

The Groovy profiler, GProf is a profiling module for Groovy. It allows you
to determine which parts of a program are taking most of the execution time
as the GNU profiler, gprof does for C and C++.

INSTALL
-------

  @Grab('org.gperfutils:gprof:0.3.0-groovy-2.1') // v0.3.0 for Groovy 2.1

or other ways to install from the Maven Central repository or build a jar
file from source code.

EXAMPLE
-------

  // slow !!
  def fib(n) {
      if (n < 2) {
          n
      } else {
          fib(n - 1) + fib(n - 2)
      }
  }

  profile {
      fib(20)
  }.prettyPrint()

  /* stdout
  Flat:

   %    cumulative   self            self     total    self    total   self    total
  time   seconds    seconds  calls  ms/call  ms/call  min ms  min ms  max ms  max ms  name
  54.3        0.29     0.29      2   145.86   267.78   38.14   58.56  253.57  477.00  demo.fib
  30.4        0.45     0.16  21890     0.00     0.00    0.00    0.00    0.80    0.80  java.lang.Integer.minus
  15.0        0.53     0.08  10945     0.00     0.00    0.00    0.00    0.83    0.83  java.lang.Integer.plus
   0.1        0.53     0.00      1     1.05   537.10    1.05  537.10    1.05  537.10  demo$_run_closure1.fib
   0.0        0.53     0.00      1     0.13   537.23    0.13  537.23    0.13  537.23  demo$_run_closure1.doCall

  Call graph:

  index  % time  self  children  calls        name
                 0.00      0.53          1/1      <spontaneous>
  [1]     100.0  0.00      0.53            1  demo$_run_closure1.doCall [1]
                 0.00      0.53          1/1      demo$_run_closure1.fib [2]
  -----------------------------------------------------------------------------
                 0.00      0.53          1/1      demo$_run_closure1.doCall [1]
  [2]      99.9  0.00      0.53            1  demo$_run_closure1.fib [2]
                 0.29      0.24          2/2      demo.fib [3]
                 0.00      0.00      2/21890      java.lang.Integer.minus [4]
                 0.00      0.00      1/10945      java.lang.Integer.plus [5]
  -----------------------------------------------------------------------------
                 0.29      0.24          2/2      demo$_run_closure1.fib [2]
  [3]      99.6  0.29      0.24      2+21888  demo.fib [3]
                 0.16      0.00  21888/21890      java.lang.Integer.minus [4]
                 0.08      0.00  10944/10945      java.lang.Integer.plus [5]
  -----------------------------------------------------------------------------
                 0.00      0.00      2/21890      demo$_run_closure1.fib [2]
                 0.16      0.00  21888/21890      demo.fib [3]
  [4]      30.4  0.16      0.00        21890  java.lang.Integer.minus [4]
  -----------------------------------------------------------------------------
                 0.00      0.00      1/10945      demo$_run_closure1.fib [2]
                 0.08      0.00  10944/10945      demo.fib [3]
  [5]      15.0  0.08      0.00        10945  java.lang.Integer.plus [5]
  -----------------------------------------------------------------------------
  */

LICENSE
-------

GProf is licensed under the term of the Apache License, Version 2.0. See
the file LICENSE for the full license.