AtomicReference
Provides atomic operations for the reference type.
using System;
using System.Diagnostics.CodeAnalysis;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using System.Threading;
namespace DotNext.Threading
{
[System.Runtime.CompilerServices.NullableContext(1)]
[System.Runtime.CompilerServices.Nullable(0)]
public static class AtomicReference
{
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static bool CompareAndSet<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, T expected, T update) where T : class
{
return Interlocked.CompareExchange(ref value, update, expected) == expected;
}
[return: System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1
})]
private static (T OldValue, T NewValue) Update<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1
})] ref ValueFunc<T, T> updater) where T : class
{
T val2;
T val;
do {
val2 = updater.Invoke(val = Volatile.Read(ref value));
} while (!CompareAndSet(ref value, val, val2));
return (val, val2);
}
[return: System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1
})]
private static (T OldValue, T NewValue) Accumulate<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, T x, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1,
1
})] ref ValueFunc<T, T, T> accumulator) where T : class
{
T val2;
T val;
do {
val2 = accumulator.Invoke(val = Volatile.Read(ref value), x);
} while (!CompareAndSet(ref value, val, val2));
return (val, val2);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static T AccumulateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, T x, Func<T, T, T> accumulator) where T : class
{
ValueFunc<T, T, T> accumulator2 = new ValueFunc<T, T, T>(accumulator, true);
return AccumulateAndGet(ref value, x, ref accumulator2);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static T AccumulateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, T x, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1,
1
})] ref ValueFunc<T, T, T> accumulator) where T : class
{
return Accumulate(ref value, x, ref accumulator).NewValue;
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
[return: NotNullIfNotNull("value")]
public static T GetAndAccumulate<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, T x, Func<T, T, T> accumulator) where T : class
{
ValueFunc<T, T, T> accumulator2 = new ValueFunc<T, T, T>(accumulator, true);
return GetAndAccumulate(ref value, x, ref accumulator2);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
[return: NotNullIfNotNull("value")]
public static T GetAndAccumulate<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, T x, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1,
1
})] ref ValueFunc<T, T, T> accumulator) where T : class
{
return Accumulate(ref value, x, ref accumulator).OldValue;
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static T UpdateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, Func<T, T> updater) where T : class
{
ValueFunc<T, T> updater2 = new ValueFunc<T, T>(updater, true);
return UpdateAndGet(ref value, ref updater2);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static T UpdateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1
})] ref ValueFunc<T, T> updater) where T : class
{
return Update(ref value, ref updater).NewValue;
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
[return: NotNullIfNotNull("value")]
public static T GetAndUpdate<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, Func<T, T> updater) where T : class
{
ValueFunc<T, T> updater2 = new ValueFunc<T, T>(updater, true);
return GetAndUpdate(ref value, ref updater2);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
[return: NotNullIfNotNull("value")]
public static T GetAndUpdate<[System.Runtime.CompilerServices.Nullable(2)] T>(ref T value, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1
})] ref ValueFunc<T, T> updater) where T : class
{
return Update(ref value, ref updater).OldValue;
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static T VolatileRead<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index) where T : class
{
return Volatile.Read(ref array[index]);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static void VolatileWrite<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T element) where T : class
{
Volatile.Write(ref array[index], element);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static bool CompareAndSet<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T expected, T update) where T : class
{
return CompareAndSet(ref array[index], expected, update);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static T CompareExchange<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T update, T comparand) where T : class
{
return Interlocked.CompareExchange(ref array[index], update, comparand);
}
public static T GetAndSet<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T update) where T : class
{
return Interlocked.Exchange(ref array[index], update);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
[return: NotNullIfNotNull("update")]
public static T SetAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T update) where T : class
{
array.VolatileWrite(index, update);
return update;
}
public static T AccumulateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T x, Func<T, T, T> accumulator) where T : class
{
ValueFunc<T, T, T> accumulator2 = new ValueFunc<T, T, T>(accumulator, true);
return array.AccumulateAndGet(index, x, ref accumulator2);
}
public static T AccumulateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T x, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1,
1
})] ref ValueFunc<T, T, T> accumulator) where T : class
{
return AccumulateAndGet(ref array[index], x, ref accumulator);
}
public static T GetAndAccumulate<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T x, Func<T, T, T> accumulator) where T : class
{
ValueFunc<T, T, T> accumulator2 = new ValueFunc<T, T, T>(accumulator, true);
return array.GetAndAccumulate(index, x, ref accumulator2);
}
public static T GetAndAccumulate<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, T x, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1,
1
})] ref ValueFunc<T, T, T> accumulator) where T : class
{
return GetAndAccumulate(ref array[index], x, ref accumulator);
}
public static T UpdateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, Func<T, T> updater) where T : class
{
ValueFunc<T, T> updater2 = new ValueFunc<T, T>(updater, true);
return array.UpdateAndGet(index, ref updater2);
}
public static T UpdateAndGet<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1
})] ref ValueFunc<T, T> updater) where T : class
{
return UpdateAndGet(ref array[index], ref updater);
}
public static T GetAndUpdate<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, Func<T, T> updater) where T : class
{
ValueFunc<T, T> updater2 = new ValueFunc<T, T>(updater, true);
return array.GetAndUpdate(index, ref updater2);
}
public static T GetAndUpdate<[System.Runtime.CompilerServices.Nullable(2)] T>(this T[] array, long index, [In] [IsReadOnly] [System.Runtime.CompilerServices.Nullable(new byte[] {
0,
1,
1
})] ref ValueFunc<T, T> updater) where T : class
{
return GetAndUpdate(ref array[index], ref updater);
}
}
}