Struct InterlockedEnum<T>
A lightweight representation of an Interlocked (atomic) Enum.
public struct InterlockedEnum<T> : IEquatable<InterlockedEnum<T>>, IComparable<InterlockedEnum<T>>, IComparable where T : struct, Enum
Type Parameters
TEnum type.
- Implements
- Inherited Members
- Extension Methods
Constructors
InterlockedEnum(T)
Creates a new InterlockedEnum<T> instance.
public InterlockedEnum(T value)
Parameters
valueTInitial value.
Properties
Value
Current value.
public T Value { get; }
Property Value
- T
Methods
CompareExchange(T, T)
Sets Value to the provided value
only if the current Value is equal to the provided comparand
and returns the old value.
public T CompareExchange(T value, T comparand)
Parameters
valueTValue to set.
comparandTValue used for Value comparison.
Returns
- T
Value before the change.
CompareTo(InterlockedEnum<T>)
Compares the current instance with another object of the same type and returns an integer that indicates whether the current instance precedes, follows, or occurs in the same position in the sort order as the other object.
[Pure]
public int CompareTo(InterlockedEnum<T> other)
Parameters
otherInterlockedEnum<T>An object to compare with this instance.
Returns
- int
A value that indicates the relative order of the objects being compared. The return value has these meanings:
Value Meaning Less than zero This instance precedes otherin the sort order.Zero This instance occurs in the same position in the sort order as other.Greater than zero This instance follows otherin the sort order.
CompareTo(object?)
Compares the current instance with another object of the same type and returns an integer that indicates whether the current instance precedes, follows, or occurs in the same position in the sort order as the other object.
[Pure]
public int CompareTo(object? obj)
Parameters
objobjectAn object to compare with this instance.
Returns
- int
A value that indicates the relative order of the objects being compared. The return value has these meanings:
Value Meaning Less than zero This instance precedes objin the sort order.Zero This instance occurs in the same position in the sort order as obj.Greater than zero This instance follows objin the sort order.
Exceptions
- ArgumentException
objis not the same type as this instance.
Equals(InterlockedEnum<T>)
Indicates whether the current object is equal to another object of the same type.
[Pure]
public bool Equals(InterlockedEnum<T> other)
Parameters
otherInterlockedEnum<T>An object to compare with this object.
Returns
Equals(object?)
Indicates whether this instance and a specified object are equal.
[Pure]
public override bool Equals(object? obj)
Parameters
objobjectThe object to compare with the current instance.
Returns
- bool
true if
objand this instance are the same type and represent the same value; otherwise, false.
Exchange(T)
Sets Value to the provided value and returns the old value.
public T Exchange(T value)
Parameters
valueTValue to set.
Returns
- T
Value before the change.
GetHashCode()
Returns the hash code for this instance.
[Pure]
public override int GetHashCode()
Returns
- int
A 32-bit signed integer that is the hash code for this instance.
ToString()
Returns a string representation of this InterlockedEnum<T> instance.
[Pure]
public override string ToString()
Returns
- string
String representation.
Write(T)
Sets Value to the provided value.
public bool Write(T value)
Parameters
valueTValue to set.
Returns
- bool
true when value has changed, otherwise false.
Write(T, T)
public bool Write(T value, T expected)
Parameters
valueTValue to set.
expectedTValue used for Value comparison.
Returns
- bool
true when value has changed, otherwise false.
Operators
operator ==(InterlockedEnum<T>, InterlockedEnum<T>)
Checks if a is equal to b.
public static bool operator ==(InterlockedEnum<T> a, InterlockedEnum<T> b)
Parameters
aInterlockedEnum<T>First operand.
bInterlockedEnum<T>Second operand.
Returns
- bool
true when operands are equal, otherwise false.
operator >(InterlockedEnum<T>, InterlockedEnum<T>)
Checks if a is greater than b.
public static bool operator >(InterlockedEnum<T> a, InterlockedEnum<T> b)
Parameters
aInterlockedEnum<T>First operand.
bInterlockedEnum<T>Second operand.
Returns
- bool
true when
ais greater thanb, otherwise false.
operator >=(InterlockedEnum<T>, InterlockedEnum<T>)
Checks if a is greater than or equal to b.
public static bool operator >=(InterlockedEnum<T> a, InterlockedEnum<T> b)
Parameters
aInterlockedEnum<T>First operand.
bInterlockedEnum<T>Second operand.
Returns
- bool
true when
ais greater than or equal tob, otherwise false.
operator !=(InterlockedEnum<T>, InterlockedEnum<T>)
Checks if a is not equal to b.
public static bool operator !=(InterlockedEnum<T> a, InterlockedEnum<T> b)
Parameters
aInterlockedEnum<T>First operand.
bInterlockedEnum<T>Second operand.
Returns
- bool
true when operands are not equal, otherwise false.
operator <(InterlockedEnum<T>, InterlockedEnum<T>)
Checks if a is less than b.
public static bool operator <(InterlockedEnum<T> a, InterlockedEnum<T> b)
Parameters
aInterlockedEnum<T>First operand.
bInterlockedEnum<T>Second operand.
Returns
- bool
true when
ais less thanb, otherwise false.
operator <=(InterlockedEnum<T>, InterlockedEnum<T>)
Checks if a is less than or equal to b.
public static bool operator <=(InterlockedEnum<T> a, InterlockedEnum<T> b)
Parameters
aInterlockedEnum<T>First operand.
bInterlockedEnum<T>Second operand.
Returns
- bool
true when
ais less than or equal tob, otherwise false.