- java.lang.Object
- 
- java.lang.invoke.VarHandle
 
- 
 public abstract class VarHandle extends Object Dynamically typed reference to a field, allowing read and write operations, both atomic and with/without memory barriers. SeeVarHandle.AccessModefor supported operations. VarHandle instances are created through the MethodHandles factory API.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classVarHandle.AccessModeAccess mode identifiers for VarHandle operations.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description MethodTypeaccessModeType(VarHandle.AccessMode accessMode)EachVarHandle.AccessMode, e.g. get and set, requires different parameters in addition to thecoordinateTypes().static voidacquireFence()Inserts an acquire memory fence, ensuring that no loads before this fence are reordered with any loads/stores after the fence.ObjectcompareAndExchange(Object... args)Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.ObjectcompareAndExchangeAcquire(Object... args)Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.ObjectcompareAndExchangeRelease(Object... args)Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.booleancompareAndSet(Object... args)Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.List<Class<?>>coordinateTypes()static voidfullFence()Inserts a complete memory fence, ensuring that no loads/stores before this fence are reordered with any loads/stores after the fence.Objectget(Object... args)Gets the value of the field referenced by thisVarHandle.ObjectgetAcquire(Object... args)Gets the value of the field referenced by thisVarHandleusing acquire semantics.ObjectgetAndAdd(Object... args)Atomically adds to the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndAddAcquire(Object... args)Atomically adds to the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndAddRelease(Object... args)Atomically adds to the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseAnd(Object... args)Atomically ANDs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseAndAcquire(Object... args)Atomically ANDs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseAndRelease(Object... args)Atomically ANDs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseOr(Object... args)Atomically ORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseOrAcquire(Object... args)Atomically ORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseOrRelease(Object... args)Atomically ORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseXor(Object... args)Atomically XORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseXorAcquire(Object... args)Atomically XORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndBitwiseXorRelease(Object... args)Atomically XORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndSet(Object... args)Atomically sets the value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndSetAcquire(Object... args)Atomically sets the value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetAndSetRelease(Object... args)Atomically sets the value of the field referenced by thisVarHandleand returns the value of the field prior to the update.ObjectgetOpaque(Object... args)Gets the value of the field referenced by thisVarHandle.ObjectgetVolatile(Object... args)Atomically gets the value of the field referenced by thisVarHandle.booleanisAccessModeSupported(VarHandle.AccessMode accessMode)Not all AccessMode are supported for allVarHandleinstances, e.g.static voidloadLoadFence()Inserts a load memory fence, ensuring that no loads before the fence are reordered with any loads after the fence.static voidreleaseFence()Inserts a release memory fence, ensuring that no loads and stores before this fence are reordered with any stores after the fence.voidset(Object... args)Sets the value of the field referenced by thisVarHandle.voidsetOpaque(Object... args)Sets the value of the field referenced by thisVarHandle.voidsetRelease(Object... args)Sets the value of the field referenced by thisVarHandleusing acquire semantics.voidsetVolatile(Object... args)Atomically sets the value of the field referenced by thisVarHandle.static voidstoreStoreFence()Inserts a store memory fence, ensuring that no stores before the fence are reordered with any stores after the fence.MethodHandletoMethodHandle(VarHandle.AccessMode accessMode)This method creates aMethodHandlefor a specificVarHandle.AccessMode.Class<?>varType()Get the type of the field thisVarHandlerefers to.booleanweakCompareAndSet(Object... args)Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.booleanweakCompareAndSetAcquire(Object... args)Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.booleanweakCompareAndSetPlain(Object... args)Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.booleanweakCompareAndSetRelease(Object... args)Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value.
 
- 
- 
- 
Method Detail- 
varTypepublic final Class<?> varType() Get the type of the field thisVarHandlerefers to.- Returns:
- The field type
 
 - 
coordinateTypespublic final List<Class<?>> coordinateTypes() Different parameters are required in order to access the field referenced by thisVarHandledepending on the type of theVarHandle, e.g. instance field, static field, or array element. This method provides a list of the access parameters for thisVarHandleinstance.- Returns:
- The parameters required to access the field.
 
 - 
accessModeTypepublic final MethodType accessModeType(VarHandle.AccessMode accessMode) EachVarHandle.AccessMode, e.g. get and set, requires different parameters in addition to thecoordinateTypes(). This method provides theMethodTypefor a specificVarHandle.AccessMode, including thecoordinateTypes().- Parameters:
- accessMode- The- VarHandle.AccessModeto get the- MethodTypefor.
- Returns:
- The MethodTypecorresponding to the providedVarHandle.AccessMode.
 
 - 
isAccessModeSupportedpublic final boolean isAccessModeSupported(VarHandle.AccessMode accessMode) Not all AccessMode are supported for allVarHandleinstances, e.g. because of the field type and/or field modifiers. This method indicates whether a specificVarHandle.AccessModeis supported by thisVarHandleinstance.- Parameters:
- accessMode- The- VarHandle.AccessModeto check support for.
- Returns:
- A boolean value indicating whether the VarHandle.AccessModeis supported.
 
 - 
toMethodHandlepublic final MethodHandle toMethodHandle(VarHandle.AccessMode accessMode) This method creates aMethodHandlefor a specificVarHandle.AccessMode. TheMethodHandleis bound to thisVarHandleinstance.- Parameters:
- accessMode- The- VarHandle.AccessModeto create a- MethodHandlefor.
- Returns:
- A MethodHandlefor the specifiedVarHandle.AccessMode, bound to thisVarHandleinstance.
 
 - 
fullFencepublic static void fullFence() Inserts a complete memory fence, ensuring that no loads/stores before this fence are reordered with any loads/stores after the fence.
 - 
acquireFencepublic static void acquireFence() Inserts an acquire memory fence, ensuring that no loads before this fence are reordered with any loads/stores after the fence.
 - 
releaseFencepublic static void releaseFence() Inserts a release memory fence, ensuring that no loads and stores before this fence are reordered with any stores after the fence.
 - 
loadLoadFencepublic static void loadLoadFence() Inserts a load memory fence, ensuring that no loads before the fence are reordered with any loads after the fence.
 - 
storeStoreFencepublic static void storeStoreFence() Inserts a store memory fence, ensuring that no stores before the fence are reordered with any stores after the fence.
 - 
getpublic final Object get(Object... args) Gets the value of the field referenced by thisVarHandle. This is a non-volatile operation.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field
 
 - 
setpublic final void set(Object... args) Sets the value of the field referenced by thisVarHandle. This is a non-volatile operation.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
 
 - 
getVolatilepublic final Object getVolatile(Object... args) Atomically gets the value of the field referenced by thisVarHandle.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field
 
 - 
setVolatilepublic final void setVolatile(Object... args) Atomically sets the value of the field referenced by thisVarHandle.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
 
 - 
getOpaquepublic final Object getOpaque(Object... args) Gets the value of the field referenced by thisVarHandle. The operation is in program order, but does enforce ordering with respect to other threads.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field
 
 - 
setOpaquepublic final void setOpaque(Object... args) Sets the value of the field referenced by thisVarHandle. The operation is in program order, but does enforce ordering with respect to other threads.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
 
 - 
getAcquirepublic final Object getAcquire(Object... args) Gets the value of the field referenced by thisVarHandleusing acquire semantics. Preceding loads will not be reordered with subsequent loads/stores.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field
 
 - 
setReleasepublic final void setRelease(Object... args) Sets the value of the field referenced by thisVarHandleusing acquire semantics. Preceding loads and stores will not be reordered after this access.- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
 
 - 
compareAndSetpublic final boolean compareAndSet(Object... args) Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofgetVolatile(Object...). The set operation has the memory semantics ofsetVolatile(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- A boolean value indicating whether the field was updated
 
 - 
compareAndExchangepublic final Object compareAndExchange(Object... args) Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofgetVolatile(Object...). The set operation has the memory semantics ofsetVolatile(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value of the field before this operation
 
 - 
compareAndExchangeAcquirepublic final Object compareAndExchangeAcquire(Object... args) Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofgetAcquire(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value of the field before this operation
 
 - 
compareAndExchangeReleasepublic final Object compareAndExchangeRelease(Object... args) Atomically sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofsetRelease(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value of the field before this operation
 
 - 
weakCompareAndSetpublic final boolean weakCompareAndSet(Object... args) Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- A boolean value indicating whether the field was updated
 
 - 
weakCompareAndSetAcquirepublic final boolean weakCompareAndSetAcquire(Object... args) Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofgetAcquire(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- A boolean value indicating whether the field was updated
 
 - 
weakCompareAndSetReleasepublic final boolean weakCompareAndSetRelease(Object... args) Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofsetRelease(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- A boolean value indicating whether the field was updated
 
 - 
weakCompareAndSetPlainpublic final boolean weakCompareAndSetPlain(Object... args) Sets the value of the field referenced by thisVarHandleif the field value before this operation equaled the expected value. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- A boolean value indicating whether the field was updated
 
 - 
getAndSetpublic final Object getAndSet(Object... args) Atomically sets the value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetVolatile(Object...). The set operation has the memory semantics ofsetVolatile(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndSetAcquirepublic final Object getAndSetAcquire(Object... args) Atomically sets the value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetAcquire(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndSetReleasepublic final Object getAndSetRelease(Object... args) Atomically sets the value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofsetRelease(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndAddpublic final Object getAndAdd(Object... args) Atomically adds to the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetVolatile(Object...). The set operation has the memory semantics ofsetVolatile(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndAddAcquirepublic final Object getAndAddAcquire(Object... args) Atomically adds to the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetAcquire(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndAddReleasepublic final Object getAndAddRelease(Object... args) Atomically adds to the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofsetRelease(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseAndpublic final Object getAndBitwiseAnd(Object... args) Atomically ANDs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetVolatile(Object...). The set operation has the memory semantics ofsetVolatile(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseAndAcquirepublic final Object getAndBitwiseAndAcquire(Object... args) Atomically ANDs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetAcquire(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseAndReleasepublic final Object getAndBitwiseAndRelease(Object... args) Atomically ANDs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics of(Object...). The set operation has the memory semantics ofsetRelease(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseOrpublic final Object getAndBitwiseOr(Object... args) Atomically ORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetVolatile(Object...). The set operation has the memory semantics ofsetVolatile(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseOrAcquirepublic final Object getAndBitwiseOrAcquire(Object... args) Atomically ORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetAcquire(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseOrReleasepublic final Object getAndBitwiseOrRelease(Object... args) Atomically ORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofsetRelease(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseXorpublic final Object getAndBitwiseXor(Object... args) Atomically XORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetVolatile(Object...). The set operation has the memory semantics ofsetVolatile(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseXorAcquirepublic final Object getAndBitwiseXorAcquire(Object... args) Atomically XORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofgetAcquire(Object...). The set operation has the memory semantics ofset(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 - 
getAndBitwiseXorReleasepublic final Object getAndBitwiseXorRelease(Object... args) Atomically XORs the provided value and the current value of the field referenced by thisVarHandleand returns the value of the field prior to the update. The get operation has the memory semantics ofget(Object...). The set operation has the memory semantics ofsetRelease(Object...).- Parameters:
- args- The arguments for this operation are determined by the field type (see- accessModeType()) and the access parameters (see- coordinateTypes()).
- Returns:
- The value stored in the field prior to the update
 
 
- 
 
-