InterlockedAnd16 function
Performs an atomic AND operation on the specified SHORT values.
Syntax
SHORT __cdecl InterlockedAnd16(
_Inout_ SHORT volatile *Destination,
_In_ SHORT Value
);
Parameters
- Destination [in, out]
-
A pointer to the first operand. This value will be replaced with the result of the operation.
- Value [in]
-
The second operand.
Return value
The function returns the original value of the Destination parameter.
Remarks
The interlocked functions provide a simple mechanism for synchronizing access to a variable that is shared by multiple threads. This function is atomic with respect to calls to other interlocked functions.
For the Intel Itanium-based systems and x64 architectures, this function is implemented using the compiler intrinsic. For the x86 architecture, use the _InterlockedAnd16 compiler intrinsic directly.
This function generates a full memory barrier (or fence) to ensure that memory operations are completed in order.
Itanium-based systems: For performance-critical applications, use InterlockedAnd16Acquire or InterlockedAnd16Release instead.
Note
Requirements
|
Header |
|
|---|
See also
- Interlocked Variable Access
- InterlockedAnd
- InterlockedAndAcquire
- InterlockedAndRelease
- InterlockedAndNoFence
- InterlockedAnd8
- InterlockedAnd8Acquire
- InterlockedAnd8Release
- InterlockedAnd8NoFence
- InterlockedAnd16Acquire
- InterlockedAnd16Release
- InterlockedAnd16NoFence
- InterlockedAnd64
- InterlockedAnd64Acquire
- InterlockedAnd64Release
- InterlockedAnd64NoFence
- Synchronization Functions