Namespaces
Variants

Concurrency support library

From cppreference.net
< c

C++ inclut une prise en charge intégrée pour les threads, les opérations atomiques, les exclusions mutuelles, les variables de condition et les stockages spécifiques aux threads.

Ces fonctionnalités sont fournies en option :

  • si la constante de macro __STDC_NO_THREADS__ est définie par le compilateur, l'en-tête <threads.h> et tous les noms qu'il fournit ne sont pas disponibles ;
  • si la constante de macro __STDC_NO_ATOMICS__ est définie par le compilateur, l'en-tête <stdatomic.h> et tous les noms qu'il fournit ne sont pas disponibles.

Voir aussi _Atomic spécificateur et qualificateur de type .

Table des matières

Fils d'exécution

Défini dans l'en-tête <threads.h>
thrd_t type d'objet complet défini par l'implémentation identifiant un thread
crée un thread
(fonction)
vérifie si deux identifiants font référence au même thread
(fonction)
obtient l'identifiant du thread actuel
(fonction)
suspend l'exécution du thread appelant pour la période de temps donnée
(fonction)
abandonne la tranche de temps actuelle
(fonction)
termine le thread appelant
(fonction)
détache un thread
(fonction)
bloque jusqu'à la terminaison d'un thread
(fonction)
indique un statut d'erreur de thread
(constante)
thrd_start_t
(C11)
un typedef du type pointeur de fonction int ( * ) ( void * ) , utilisé par thrd_create
(typedef)

Opérations atomiques

Défini dans l'en-tête <stdatomic.h>
Opérations sur les types atomiques
indique que le type atomique donné est sans verrou
(constante de macro)
indique si l'objet atomique est sans verrou
(fonction)
stocke une valeur dans un objet atomique
(fonction)
lit une valeur depuis un objet atomique
(fonction)
échange une valeur avec la valeur d'un objet atomique
(fonction)
échange une valeur avec un objet atomique si l'ancienne valeur correspond à celle attendue, sinon lit l'ancienne valeur
(fonction)
addition atomique
(fonction)
soustraction atomique
(fonction)
OU binaire atomique
(fonction)
OU exclusif atomique au niveau du bit
(fonction)
ET atomique bit à bit
(fonction)
Type de drapeau et opérations
indicateur booléen atomique sans verrouillage
(struct)
définit un atomic_flag à true et retourne l'ancienne valeur
(fonction)
définit un atomic_flag à false
(fonction)
Initialisation
initialise un objet atomique existant
(fonction)
(C11) (obsolète en C17) (supprimé en C23)
initialise un nouvel objet atomique
(macro de fonction)
initialise un nouveau atomic_flag
(constante macro)
Ordre de synchronisation de la mémoire
définit les contraintes d'ordonnancement de la mémoire
(enum)
rompt une chaîne de dépendance pour memory_order_consume
(macro fonction)
primitive de synchronisation de barrière générique dépendant de l'ordre mémoire
(fonction)
barrière entre un thread et un gestionnaire de signal exécuté dans le même thread
(fonction)
Alias de type de commodité
Nom du typedef Nom complet du type
atomic_bool (C11) _Atomic _Bool (jusqu'à C23) _Atomic bool (depuis C23)
atomic_char (C11) _Atomic char
atomic_schar (C11) _Atomic signed char
atomic_uchar (C11) _Atomic unsigned char
atomic_short (C11) _Atomic short
atomic_ushort (C11) _Atomic unsigned short
atomic_int (C11) _Atomic int
atomic_uint (C11) _Atomic unsigned int
atomic_long (C11) _Atomic long
atomic_ulong (C11) _Atomic unsigned long
atomic_llong (C11) _Atomic long long
atomic_ullong (C11) _Atomic unsigned long long
atomic_char8_t (C23) _Atomic char8_t
atomic_char16_t (C11) _Atomic char16_t
atomic_char32_t (C11) _Atomic char32_t
atomic_wchar_t (C11) _Atomic wchar_t
atomic_int_least8_t (C11) _Atomic int_least8_t
atomic_uint_least8_t (C11) _Atomic uint_least8_t
atomic_int_least16_t (C11) _Atomic int_least16_t
atomic_uint_least16_t (C11) _Atomic uint_least16_t
atomic_int_least32_t (C11) _Atomic int_least32_t
atomic_uint_least32_t (C11) _Atomic uint_least32_t
atomic_int_least64_t (C11) _Atomic int_least64_t
atomic_uint_least64_t (C11) _Atomic uint_least64_t
atomic_int_fast8_t (C11) _Atomic int_fast8_t
atomic_uint_fast8_t (C11) _Atomic uint_fast8_t
atomic_int_fast16_t (C11) _Atomic int_fast16_t
atomic_uint_fast16_t (C11) _Atomic uint_fast16_t
atomic_int_fast32_t (C11) _Atomic int_fast32_t
atomic_uint_fast32_t (C11) _Atomic uint_fast32_t
atomic_int_fast64_t (C11) _Atomic int_fast64_t
atomic_uint_fast64_t (C11) _Atomic uint_fast64_t
atomic_intptr_t (C11) _Atomic intptr_t
atomic_uintptr_t (C11) _Atomic uintptr_t
atomic_size_t (C11) _Atomic size_t
atomic_ptrdiff_t (C11) _Atomic ptrdiff_t
atomic_intmax_t (C11) _Atomic intmax_t
atomic_uintmax_t (C11) _Atomic uintmax_t

Exclusion mutuelle

Défini dans l'en-tête <threads.h>
mtx_t identifiant de mutex
crée un mutex
(fonction)
bloque jusqu'à l'obtention du verrou d'un mutex
(fonction)
bloque jusqu'à l'obtention du verrou d'un mutex ou expiration du délai
(fonction)
verrouille un mutex ou retourne sans bloquer s'il est déjà verrouillé
(fonction)
déverrouille un mutex
(fonction)
détruit un mutex
(fonction)
définit le type d'un mutex
(énumération)
Appel unique
appelle une fonction exactement une fois
(fonction)

Variables de condition

Défini dans l'en-tête <threads.h>
cnd_t identifiant de variable de condition
crée une variable de condition
(fonction)
débloque un thread bloqué sur une variable de condition
(fonction)
débloque tous les threads bloqués sur une variable de condition
(fonction)
se bloque sur une variable de condition
(fonction)
se bloque sur une variable de condition, avec un délai d'attente
(fonction)
détruit une variable de condition
(fonction)

Stockage local au thread

Défini dans l'en-tête <threads.h>
(C11) (supprimé en C23)
macro de commodité pour le spécificateur de classe de stockage _Thread_local
(macro mot-clé)
tss_t pointeur de stockage spécifique au thread
nombre maximum d'appels aux destructeurs
(constante macro)
tss_dtor_t
(C11)
type de pointeur de fonction void ( * ) ( void * ) , utilisé pour le destructeur TSS
(typedef)
crée un pointeur de stockage spécifique au thread avec un destructeur donné
(fonction)
(C11)
lit depuis le stockage spécifique au thread
(fonction)
(C11)
écrit dans le stockage spécifique au thread
(fonction)
libère les ressources détenues par un pointeur spécifique au thread donné
(fonction)

Identifiants réservés

Dans les révisions futures de la norme C :

  • Les noms de fonctions, noms de types et constantes d'énumération commençant par cnd_ , mtx_ , thrd_ , ou tss_ suivis d'une lettre minuscule peuvent être ajoutés aux déclarations dans l'en-tête <threads.h> ;
  • Les macros commençant par ATOMIC_ suivies d'une lettre majuscule peuvent être ajoutées aux macros définies dans l'en-tête <stdatomic.h> ;
  • Les noms de types (typedef) commençant par atomic_ ou memory_ suivis d'une lettre minuscule peuvent être ajoutés aux déclarations dans l'en-tête <stdatomic.h> ;
  • Les constantes d'énumération commençant par memory_order_ suivies d'une lettre minuscule peuvent être ajoutées à la définition du type memory_order dans l'en-tête <stdatomic.h> ;
  • Les noms de fonctions commençant par atomic_ suivis d'une lettre minuscule peuvent être ajoutés aux déclarations dans l'en-tête <stdatomic.h> .

Les identificateurs réservés pour les noms de fonctions sont toujours potentiellement (since C23) réservés pour une utilisation comme identificateurs avec liaison externe, tandis que les autres identificateurs listés ici sont potentiellement (since C23) réservés lorsque <stdatomic.h> est inclus.

Déclarer, définir, ou #undef un tel identifiant entraîne un comportement indéfini s'il est fourni par la norme ou l'implémentation (depuis C23) . Les programmes portables ne devraient pas utiliser ces identifiants.

Références

  • Norme C23 (ISO/CEI 9899:2024) :
  • 7.17 Atomics <stdatomic.h> (p: TBD)
  • 7.26 Threads <threads.h> (p: TBD)
  • 7.31.8 Atomics <stdatomic.h> (p: TBD)
  • 7.31.15 Threads <threads.h> (p: TBD)
  • Norme C17 (ISO/CEI 9899:2018) :
  • 7.17 Atomics <stdatomic.h> (p: 200-209)
  • 7.26 Threads <threads.h> (p: 274-283)
  • 7.31.8 Atomics <stdatomic.h> (p: 332)
  • 7.31.15 Threads <threads.h> (p: 333)
  • Norme C11 (ISO/IEC 9899:2011) :
  • 7.17 Atomics <stdatomic.h> (p: 273-286)
  • 7.26 Threads <threads.h> (p: 376-387)
  • 7.31.8 Atomics <stdatomic.h> (p: 455-456)
  • 7.31.15 Threads <threads.h> (p: 456)

Voir aussi

Documentation C++ pour Bibliothèque de support de la concurrence

Liens externes

Manuel GNU GCC Libc : Mutexes ISO C