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

checker.src.org.checkerframework.checker.lock.qual.LockingFree Maven / Gradle / Ivy

Go to download

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.

There is a newer version: 3.42.0
Show newest version
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 { }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy