Функция InterlockedCompareExchange (справочник по HLSL)

Атомарно сравнивает назначение со значением сравнения. Если они идентичны, назначение перезаписывается входным значением. Исходному значению присваивается исходное значение назначения.

Синтаксис

void InterlockedCompareExchange(
  in  R dest,
  in  T compare_value,
  in  T value,
  out T original_value
);

Параметры

dest [in]

Тип: R

Адрес назначения.

compare_value [in]

Тип: T

Значение сравнения.

value [in]

Тип: T

Входное значение.

original_value [out]

Тип: T

Исходное значение.

Возвращаемое значение

Эта функция не возвращает значение.

Комментарии

Атомарно сравнивает значение, на которое ссылается dest , с compare_value, сохраняет значение в расположении, на которое ссылается dest , если значения совпадают, возвращает исходное значение dest в original_value. Эта операция может выполняться только с типизированными ресурсами int или uint и переменными общей памяти. Существует два возможных варианта использования этой функции. Во-первых, R является типом переменной общей памяти. В этом случае функция выполняет операцию с регистром общей памяти, на который ссылается dest. Второй сценарий — это ситуация, когда R является типом переменной ресурса. В этом сценарии функция выполняет операцию с расположением ресурса, на который ссылается dest. Эта операция доступна только в том случае, если R доступен для чтения и записи.

Операции с блокировкой не подразумевают границы памяти или барьеры.

Примечание

Если вы вызываете InterlockedCompareExchange в цикле шейдера вычислений for или while , для правильной компиляции необходимо использовать атрибут [allow_uav_condition] в этом цикле.

 

Минимальная модель шейдера

Эта функция поддерживается в следующих моделях шейдеров.

Модель шейдера Поддерживается
Модели шейдеров 5 и более поздних версий шейдеров да

 

Эта функция поддерживается в следующих типах шейдеров:

Вершина Корпуса Домен Geometry Пиксель Вычисления
x x x x x x

 

См. также раздел

Встроенные функции

Модель шейдера 5