checker.src.org.checkerframework.checker.lock.qual.LockingFree Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of checker Show documentation
Show all versions of checker Show documentation
The Checker Framework enhances Java’s type system to
make it more powerful and useful. This lets software developers
detect and prevent errors in their Java programs.
The Checker Framework includes compiler plug-ins ("checkers")
that find bugs or verify their absence. It also permits you to
write your own compiler plug-ins.
package org.checkerframework.checker.lock.qual;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.checkerframework.dataflow.qual.Pure;
import org.checkerframework.dataflow.qual.SideEffectFree;
import org.checkerframework.framework.qual.InheritedAnnotation;
/**
* The method neither acquires nor releases locks, nor do any of the
* methods that it calls.
* More specifically, the method is not {@code synchronized}, it
* contains no {@code synchronized} blocks, it contains no calls to
* {@code lock} or {@code unlock}, and it contains no calls to other
* non-{@code @LockingFree} methods.
*
*
* {@code @LockingFree} provides a stronger guarantee than
* {@code @}{@link ReleasesNoLocks} and a weaker guarantee than
* {@code @}{@link SideEffectFree}.
*
* @see MayReleaseLocks
* @see ReleasesNoLocks
* @see SideEffectFree
* @see Pure
* @checker_framework.manual #lock-checker Lock Checker
* @checker_framework.manual #lock-lockingfree-example Example use of @LockingFree
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@InheritedAnnotation
@Target({ ElementType.METHOD, ElementType.CONSTRUCTOR })
public @interface LockingFree {
}