Concurrency support library
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 |
|
(C11)
|
crée un thread
(fonction) |
|
(C11)
|
vérifie si deux identifiants font référence au même thread
(fonction) |
|
(C11)
|
obtient l'identifiant du thread actuel
(fonction) |
|
(C11)
|
suspend l'exécution du thread appelant pour la période de temps donnée
(fonction) |
|
(C11)
|
abandonne la tranche de temps actuelle
(fonction) |
|
(C11)
|
termine le thread appelant
(fonction) |
|
(C11)
|
détache un thread
(fonction) |
|
(C11)
|
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) |
|
|
(C11)
|
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 |
|
|
(C11)
|
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 |
|
|
(C11)
|
initialise un objet atomique existant
(fonction) |
|
(C11)
(obsolète en C17)
(supprimé en C23)
|
initialise un nouvel objet atomique
(macro de fonction) |
|
(C11)
|
initialise un nouveau
atomic_flag
(constante macro) |
Ordre de synchronisation de la mémoire |
|
|
(C11)
|
définit les contraintes d'ordonnancement de la mémoire
(enum) |
|
(C11)
|
rompt une chaîne de dépendance pour
memory_order_consume
(macro fonction) |
|
(C11)
|
primitive de synchronisation de barrière générique dépendant de l'ordre mémoire
(fonction) |
|
(C11)
|
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 |
|
(C11)
|
crée un mutex
(fonction) |
|
(C11)
|
bloque jusqu'à l'obtention du verrou d'un mutex
(fonction) |
|
(C11)
|
bloque jusqu'à l'obtention du verrou d'un mutex ou expiration du délai
(fonction) |
|
(C11)
|
verrouille un mutex ou retourne sans bloquer s'il est déjà verrouillé
(fonction) |
|
(C11)
|
déverrouille un mutex
(fonction) |
|
(C11)
|
détruit un mutex
(fonction) |
|
(C11)
(C11)
(C11)
|
définit le type d'un mutex
(énumération) |
Appel unique |
|
|
(C11)
|
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 |
|
(C11)
|
crée une variable de condition
(fonction) |
|
(C11)
|
débloque un thread bloqué sur une variable de condition
(fonction) |
|
(C11)
|
débloque tous les threads bloqués sur une variable de condition
(fonction) |
|
(C11)
|
se bloque sur une variable de condition
(fonction) |
|
(C11)
|
se bloque sur une variable de condition, avec un délai d'attente
(fonction) |
|
(C11)
|
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 |
|
(C11)
|
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) |
|
(C11)
|
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) |
|
(C11)
|
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_, outss_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_oumemory_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 |