Namespaces
Variants

atomic_fetch_sub, atomic_fetch_sub_explicit

From cppreference.net
Défini dans l'en-tête <stdatomic.h>
C atomic_fetch_sub ( volatile A * obj, M arg ) ;
(1) (depuis C11)
C atomic_fetch_sub_explicit ( volatile A * obj, M arg, memory_order order ) ;
(2) (depuis C11)

Remplace atomiquement la valeur pointée par obj par le résultat de la soustraction de arg à l'ancienne valeur de obj , et retourne la valeur que obj contenait précédemment. L'opération est une opération de lecture-modification-écriture. La première version ordonne les accès mémoire selon memory_order_seq_cst , la deuxième version ordonne les accès mémoire selon order .

Ceci est une fonction générique définie pour tous les types d'objets atomiques A . L'argument est un pointeur vers un type atomique volatile pour accepter les adresses des objets atomiques non volatiles et volatiles (par exemple, E/S mappées en mémoire), et la sémantique volatile est préservée lors de l'application de cette opération aux objets atomiques volatiles. M est soit le type non atomique correspondant à A si A est un type entier atomique, soit ptrdiff_t si A est un type pointeur atomique.

Il n'est pas spécifié si le nom d'une fonction générique est une macro ou un identifiant déclaré avec une liaison externe. Si une définition de macro est supprimée pour accéder à une fonction réelle (par exemple entre parenthèses comme ( atomic_fetch_sub ) ( ... ) ), ou si un programme définit un identifiant externe avec le nom d'une fonction générique, le comportement est indéfini.

Pour les types entiers signés, l'arithmétique est définie pour utiliser la représentation en complément à deux. Il n'y a pas de résultats non définis. Pour les types pointeurs, le résultat peut être une adresse non définie, mais les opérations n'ont par ailleurs aucun comportement non défini.

Table des matières

Paramètres

obj - pointeur vers l'objet atomique à modifier
arg - valeur à soustraire de la valeur stockée dans l'objet atomique
order - ordre de synchronisation mémoire pour cette opération : toutes les valeurs sont autorisées

Valeur de retour

La valeur précédemment détenue par l'objet atomique pointé par obj .

Références

  • Norme C17 (ISO/CEI 9899:2018) :
  • 7.17.7.5 Les fonctions génériques atomic_fetch et modify (p: 208)
  • Norme C11 (ISO/CEI 9899:2011) :
  • 7.17.7.5 Les fonctions génériques atomic_fetch et modify (p: 284-285)

Voir aussi

addition atomique
(fonction)
Documentation C++ pour atomic_fetch_sub , atomic_fetch_sub_explicit