patterntesting.runtime.annotation.ProfileMe Maven / Gradle / Ivy
Go to download
PatternTesting Runtime (patterntesting-rt) is the runtime component for
the PatternTesting framework. It provides the annotations and base classes
for the PatternTesting testing framework (e.g. patterntesting-check,
patterntesting-concurrent or patterntesting-exception) but can be also
used standalone for classpath monitoring or profiling.
It uses AOP and AspectJ to perform this feat.
The newest version!
/**
* $Id: ProfileMe.java,v 1.4 2009/12/19 22:34:09 oboehm Exp $
*
* Copyright (c) 2008 by Oliver Boehm
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express orimplied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* (c)reated 19.12.2008 by oliver ([email protected])
*/
package patterntesting.runtime.annotation;
import java.lang.annotation.*;
/**
* You want to measure a method or constructor? Mark it with @ProfileMe.
* You want to measure all methods or constructors in a class? Mark the
* class with @ProfileMe.
*
* You want to find constructors or methods of a class which are never called?
* Mark the class with @ProfileMe and look at the constructors and methods
* which has a hit of "0". This feature works only if you mark the whole class
* with @ProfileMe because in this case the ProfileStatisticMBean initializes
* the ProfileMonitor for each method in this class.
*
* For all other methods
* or constructors the attached ProfileMonitor is initialized at the first
* call. So you don't see the ProfileMonitor if the method or constructor
* is never called.
*
* Note: This works only for classes which are really loaded.
* If a class is loaded you can see it with the ClasspathMonitorMBean.
*
* @see DontProfileMe
* @see patterntesting.runtime.monitor.ProfileStatistic
* @see patterntesting.runtime.monitor.ProfileStatistic
* @see patterntesting.runtime.monitor.ProfileMonitor
* @see patterntesting.runtime.monitor.ClasspathMonitor
* @see patterntesting.runtime.monitor.ClasspathMonitorMBean
*
* @author oliver
* @since 19.12.2008
* @version $Revision: 1.4 $
*/
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.CONSTRUCTOR, ElementType.METHOD, ElementType.TYPE})
public @interface ProfileMe {
}
/**
* $Log: ProfileMe.java,v $
* Revision 1.4 2009/12/19 22:34:09 oboehm
* trailing spaces removed
*
* Revision 1.3 2009/04/25 21:13:45 oboehm
* @DontProfileMe is provided now (fixes 2777814)
*
* Revision 1.2 2009/04/03 21:30:09 oboehm
* with (Abstract)ProfileAspect it is now possible
* to find methods/constructors which are never called
*
* Revision 1.1 2008/12/22 15:59:15 oboehm
* ProfileAspect as simple profiler replacement added
*
* $Source: /cvsroot/patterntesting/PatternTesting08/patterntesting-rt/src/main/java/patterntesting/runtime/annotation/ProfileMe.java,v $
*/