atomic_sub()

Безопасно отнять число от переменной

Прототип:

#include <atomic.h>
void atomic_sub( volatile unsigned *loc,
unsigned decr );

Аргументы:

loc
Указатель на переменную из которой требуется вычесть число.
decr
Число, которое требуется вычесть.

Библиотека:

libc

Описание:

Функция atomic_sub() представляет собой потокобезопасный способ выполнения операции (*loc) -= decr, даже в системах с симметричной многопроцессорностью.

Функции atomic_*() гарантировано выполняются без вытеснения другим потоком. При модификации переменной совместно используемой в потоке и прерываниях, необходимо либо запрещать прерывания, либо использовать функции atomic_*().

Функции atomic_*() полезны для модификации переменной используемой в нескольких потоках (которые не обязательно принадлежат одному процессу) без необходимости в использовании мьютекса.


Caution: Производите атомарные операции только с объектами находящимися в памяти с нормальным мапированием. На определённых процессорах (например некоторые PPC) атомарные операции будут вызывать сбои, если объект находится в памяти без кэширования.

Примеры:

Безопасное вычитание числа 1 из счётчика:

#include <atomic.h>
...
volatile unsigned count;
...
atomic_sub( &count, 1 );

Классификация:

ЗОСРВ «Нейтрино»

Безопасность использования
Точка остановки потока
Нет
Обработчик прерываний
Да
Обработчик сигналов
Да
В потоке
Да

Тематические ссылки:

atomic_add(), atomic_add_value(), atomic_clr(), atomic_clr_value(), atomic_set(), atomic_set_value(), atomic_sub_value(), atomic_toggle(), atomic_toggle_value()




Предыдущий раздел: Описание API системной библиотеки