Sécurité des threads dans la bibliothèque standard C++

 

Pour obtenir la dernière documentation sur Visual Studio 2017, consultez Documentation Visual Studio 2017.

Les règles de sécurité des threads suivantes s'appliquent à toutes les classes de la bibliothèque C++ standard, y compris shared_ptr, comme décrit ci-dessous. De meilleures garanties sont parfois fournies, par exemple les objets iostream standard, comme décrit ci-dessous, ainsi que des types spécifiquement destinés au multithreading, comme ceux dans <atomic>.

Un objet est thread-safe pour la lecture à partir de plusieurs threads. Par exemple, étant donné un objet A, la lecture de A à partir du thread 1 et du thread 2 simultanément est sécurisée.

Si un thread écrit dans un objet, toutes les lectures et écritures dans cet objet sur le même thread ou d'autres threads doivent être protégées. Par exemple, étant donné un objet A, si le thread 1 écrit dans A, le thread 2 doit être dans l'impossibilité d'écrire ou de lire dans A.

La lecture et l'écriture dans une instance d'un type sont sécurisées, même si un autre thread lit ou écrit dans une autre instance du même type. Par exemple, étant donné des objets A et B du même type, l'opération est sécurisée quand A est écrit dans le thread 1 et que B est lu dans le thread 2.

Plusieurs threads peuvent lire et écrire simultanément dans différents objets shared_ptr, même quand les objets sont des copies qui partagent la propriété.

Les objets iostream standard cin, cout, cerr, clog, wcin, wcout, wcerr et wclog suivent les mêmes règles que les autres classes, à cette exception près : l'écriture dans un objet à partir de plusieurs threads est sécurisée. Par exemple, le thread 1 peut écrire dans cout en même temps que le thread 2. Toutefois, les sorties des deux threads peuvent alors être mélangées.

System_CAPS_ICON_note.jpg Remarque

La lecture à partir d'une mémoire tampon de flux n'est pas considérée comme étant une opération de lecture. Elle est plutôt considérée comme une opération d'écriture, car l'état de la classe est modifié.

Vue d'ensemble de la bibliothèque STL

Afficher: