All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cdc.perfs.package-info Maven / Gradle / Ivy

There is a newer version: 0.52.1
Show newest version
/**
 * Declaration of main types used to create measures.
 * 

* An {@code Environment} is associated to an execution * environment.
* There is one living {@code RuntimeEnvironment} associated * to currently running VM. * New measures can be added to the RuntimeEnvironment.
* There are as many {@code SnapshotEnvironment}s as needed. * They are created by making snapshot of another environment or retrieved from * a saved Environment. * An Environment can be saved to a file. Loading such a file produces a * SnapshotEnvironment. *

* {@code Measure}s are created in a Context corresponding to a Thread and are * associated to a {@code Source}. * Each measure has a {@code Level} of importance. *

* A {@code Source} can correspond to a class, a package or anything else. *

* A {@code RuntimeProbe} is used to create {@code RuntimeMeasure}s. *

* In a {@code Context}, {@code Measure}s are organized as a tree.
* Starting and ending {@code Measure}s should be well balanced.
* If this not the case (wrong code, not handled exception, ...), * {@code Measure}s can be automatically ended or started. * Such a Measure can be recognized by its {@code FROZEN_ON_ERROR} status. *

* A typical usage follows: * *

 * class A {
 *     private static final Source SOURCE = RuntimeEnvironment.getInstance().getSource(A.class);
 *
 *     public void foo() {
 *         final RuntimeProbe probe = RuntimeEnvironment.getInstance().createProbe(SOURCE, MeasureLevel.INFO);
 *         probe.start("foo()");
 *         try {
 *            // Do something
 *         finally {
 *            probe.stop();
 *         }
 *     }
 * }
 * 
* * Creating probes and making measures has a cost (time and memory). *

* Setting source maximum level can be used to control memory usage. * Creating a measure for a disabled source has almost no memory cost (A cache * of shared probes is used for that). * Practically, except for most sensitive code, probes can be left in * production code. * * @author Damien Carbonne */ package cdc.perfs;





© 2015 - 2025 Weber Informatics LLC | Privacy Policy