Maison développement back-end tutoriel php Linux – Synchronisation des threads et exclusion mutuelle

Linux – Synchronisation des threads et exclusion mutuelle

Jan 18, 2017 am 10:32 AM

1. Mutex mutex
Synchronisation : accès aux ressources de manière ordonnée. Exclusion mutuelle : un seul s'exécute à la fois ; mais pour les programmes multithread, le problème des conflits d'accès est très courant. La solution consiste à introduire un mutex (Mutex, MutualExclusive Lock) et à obtenir le verrou. l'opération "lecture-modification-écriture", puis relâchez le verrou sur les autres threads qui n'ont pas obtenu le verrou ne peuvent qu'attendre mais ne peuvent pas accéder aux données partagées. De cette manière, l'opération en trois étapes "lecture-modification-écriture". write" forme une opération atomique. Soit les exécuter tous, soit aucun, ils ne seront pas interrompus en cours d'exécution, et cette opération ne se fera pas en parallèle sur les autres processeurs.
Les verrous Mutex sont représentés par des variables de type pthread_mutex_t. Initialisé avec pthread_mutex_init et détruit avec hread_destroy(). Renvoie 0 en cas de succès et un numéro d'erreur en cas d'échec. . Si la variable Mutex est allouée statiquement (variable globale ou variable statique), elle peut également être initialisée avec la définition de macro PTHREAD_MUTEX_INITIALIZER, ce qui équivaut à une initialisation avec pthread_mutex_init et le paramètre attr est NULL
Un thread peut appeler pthread_mutex_lock pour obtenir le Mutex.Si à ce moment un autre thread Si le thread a appelé pthread_mutex_lock pour obtenir le Mutex, le thread actuel doit attendre qu'un autre thread appelle pthread_mutex_unlock pour libérer le Mutex, et le thread actuel est réveillé avant de pouvoir obtenir le Mutex et continuer l'exécution. . Cela signifie que si un thread verrouille le mutex mais ne le déverrouille pas, et qu'un autre thread veut obtenir le mutex, il doit raccrocher et attendre que le thread verrouillé déverrouille le mutex et libère le mutex, puis le thread est réveillé et peut obtenir le mutex.
Si un thread veut obtenir le verrou mais ne veut pas se bloquer et attendre, il peut appeler pthread_mutex_trylock. Si le Mutex a été acquis par un autre thread, cette fonction échouera et retournera EBUSY sans provoquer le thread. pendre et attendre.

1 #include<stdio.h>  
  2 #include<stdlib.h>  
  3 #include<pthread.h>  
  4 static int g_count=0;  
  5 void * addWrite(void * arg)  
  6 {  
  7     int count=0;  
  8     int value=0;  
  9     while(count++ <5000)  
 10     {  
 11         value=g_count;  
 12         printf("g_count is %d\n",g_count);  
 13         g_count=value+1;  
 14     }  
 15 }  
 16 int main()  
 17 {  
 18     pthread_t id1;  
 19     pthread_t id2;  
 20     int ret=pthread_create(&id1,NULL,addWrite,NULL);  
 21     int res=pthread_create(&id2,NULL,addWrite,NULL);  
 22     pthread_join(id1,NULL);  
 23     pthread_join(id2,NULL);
Copier après la connexion

Nous créons deux threads, chacun augmentant g_count 5000 fois Normalement le compteur final devrait être égal à 10000, mais en fait le résultat est différent à chaque exécution du programme, parfois il atteint 5000. Parfois je le fais. comptez plus de 6 000, mais après avoir ajouté le verrou, ajoutez pthread_mutex_init sur la cinquième ligne (comme indiqué ci-dessous)

Linux – Synchronisation des threads et exclusion mutuelle

Résultat :

Linux – Synchronisation des threads et exclusion mutuelle

Après avoir ajouté le verrou, il génère 10000
2. Principe de mise en œuvre du verrouillage et du déverrouillage

Afin de réaliser l'opération de verrouillage mutex, la plupart des architectures fournissent des instructions d'échange ou d'échange. L'instruction consiste à échanger des données entre le registre et l'unité de mémoire. Puisqu'il n'y a qu'une seule instruction, l'atomicité est garantie. Même sur une plate-forme multiprocesseur, les cycles de bus pour accéder à la mémoire sont séquentiels. L'instruction d'échange sur un processeur est exécutée. quand un autre Les instructions d'échange du processeur ne peuvent attendre que les cycles de bus. Ceci est montré dans le pseudocode ci-dessous. L'opération de déverrouillage en déverrouillage est également mise en œuvre avec une seule instruction pour garantir son atomicité.

Linux – Synchronisation des threads et exclusion mutuelle

3. Deadlock
・Généralement, si le même thread appelle lock deux fois, lors du deuxième appel, parce que le verrou a déjà été occupé, le thread raccrochera. et attendez que d'autres threads libèrent le verrou. Cependant, le thread est suspendu sans possibilité de libérer le verrou, il sera donc dans un état d'attente suspendu pour toujours. Une autre situation de blocage typique est la suivante : le thread A acquiert le verrou 1 et le thread B acquiert le verrou 2. À ce moment-là, le thread A appelle le verrou pour tenter d'acquérir le verrou 2. Par conséquent, il doit se bloquer et attendre que le thread B se libère. lock 2, et ceci Lorsque le thread B appelle également lock pour essayer d'obtenir le verrou 1, le résultat est qu'il doit attendre que le thread A libère le verrou 1, donc les deux threads A et B sont dans un état suspendu pour toujours.
Conditions de formation d'un blocage
① Condition d'exclusion mutuelle : une ressource ne peut être utilisée que par un seul thread à la fois.
②.Conditions de demande et de conservation : Lorsqu'un processus est bloqué en raison d'une demande de ressources, il conservera les ressources obtenues.

③. Conditions de non-privation : Les ressources obtenues par le processus ne peuvent pas être privées de force avant d'être épuisées.

④Condition d'attente cyclique : une relation de ressources d'attente cyclique tête-à-queue est formée entre plusieurs processus

Si plus de threads et plus de verrous sont impliqués, cela est plus susceptible de provoquer un problème de blocage. Lors de l'écriture d'un programme, vous devez essayer d'éviter d'acquérir plusieurs verrous en même temps. Si cela est nécessaire, il existe un principe : si tous les threads ont besoin de plusieurs verrous, ils doivent suivre le même ordre (le plus courant est le même). ordre d'adresse de la variable Mutex) Si le verrou est obtenu, le blocage ne se produira pas. Par exemple, si le verrou 1, le verrou 2 et le verrou 3 sont utilisés dans un programme et que les adresses de leurs variables Mutex correspondantes sont verrou 1

Ce qui précède est le contenu de la synchronisation des threads Linux et de l'exclusion mutuelle. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.php.cn) !


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Différence entre Centos et Ubuntu Différence entre Centos et Ubuntu Apr 14, 2025 pm 09:09 PM

Les principales différences entre Centos et Ubuntu sont: l'origine (Centos provient de Red Hat, pour les entreprises; Ubuntu provient de Debian, pour les particuliers), la gestion des packages (Centos utilise Yum, se concentrant sur la stabilité; Ubuntu utilise APT, pour une fréquence de mise à jour élevée), le cycle de support (CentOS fournit 10 ans de soutien, Ubuntu fournit un large soutien de LT tutoriels et documents), utilisations (Centos est biaisé vers les serveurs, Ubuntu convient aux serveurs et aux ordinateurs de bureau), d'autres différences incluent la simplicité de l'installation (Centos est mince)

Comment installer CentOS Comment installer CentOS Apr 14, 2025 pm 09:03 PM

Étapes d'installation de CentOS: Téléchargez l'image ISO et Burn Bootable Media; démarrer et sélectionner la source d'installation; sélectionnez la langue et la disposition du clavier; configurer le réseau; partitionner le disque dur; définir l'horloge système; créer l'utilisateur racine; sélectionnez le progiciel; démarrer l'installation; Redémarrez et démarrez à partir du disque dur une fois l'installation terminée.

Le choix de Centos après l'arrêt de l'entretien Le choix de Centos après l'arrêt de l'entretien Apr 14, 2025 pm 08:51 PM

CentOS a été interrompu, les alternatives comprennent: 1. Rocky Linux (meilleure compatibilité); 2. Almalinux (compatible avec CentOS); 3. Serveur Ubuntu (configuration requise); 4. Red Hat Enterprise Linux (version commerciale, licence payante); 5. Oracle Linux (compatible avec Centos et Rhel). Lors de la migration, les considérations sont: la compatibilité, la disponibilité, le soutien, le coût et le soutien communautaire.

Explication détaillée du principe docker Explication détaillée du principe docker Apr 14, 2025 pm 11:57 PM

Docker utilise les fonctionnalités du noyau Linux pour fournir un environnement de fonctionnement d'application efficace et isolé. Son principe de travail est le suivant: 1. Le miroir est utilisé comme modèle en lecture seule, qui contient tout ce dont vous avez besoin pour exécuter l'application; 2. Le Système de fichiers Union (UnionFS) empile plusieurs systèmes de fichiers, ne stockant que les différences, l'économie d'espace et l'accélération; 3. Le démon gère les miroirs et les conteneurs, et le client les utilise pour l'interaction; 4. Les espaces de noms et les CGROUP implémentent l'isolement des conteneurs et les limitations de ressources; 5. Modes de réseau multiples prennent en charge l'interconnexion du conteneur. Ce n'est qu'en comprenant ces concepts principaux que vous pouvez mieux utiliser Docker.

Comment utiliser Docker Desktop Comment utiliser Docker Desktop Apr 15, 2025 am 11:45 AM

Comment utiliser Docker Desktop? Docker Desktop est un outil pour exécuter des conteneurs Docker sur les machines locales. Les étapes à utiliser incluent: 1. Installer Docker Desktop; 2. Démarrer Docker Desktop; 3. Créer une image Docker (à l'aide de DockerFile); 4. Build Docker Image (en utilisant Docker Build); 5. Exécuter Docker Container (à l'aide de Docker Run).

Que faire après Centos arrête la maintenance Que faire après Centos arrête la maintenance Apr 14, 2025 pm 08:48 PM

Une fois CentOS arrêté, les utilisateurs peuvent prendre les mesures suivantes pour y faire face: sélectionnez une distribution compatible: comme Almalinux, Rocky Linux et CentOS Stream. Migrez vers les distributions commerciales: telles que Red Hat Enterprise Linux, Oracle Linux. Passez à Centos 9 Stream: Rolling Distribution, fournissant les dernières technologies. Sélectionnez d'autres distributions Linux: comme Ubuntu, Debian. Évaluez d'autres options telles que les conteneurs, les machines virtuelles ou les plates-formes cloud.

Que faire si l'image Docker échoue Que faire si l'image Docker échoue Apr 15, 2025 am 11:21 AM

Dépannage des étapes pour la construction d'image Docker échouée: cochez la syntaxe Dockerfile et la version de dépendance. Vérifiez si le contexte de construction contient le code source et les dépendances requis. Affichez le journal de construction pour les détails d'erreur. Utilisez l'option - cibler pour créer une phase hiérarchique pour identifier les points de défaillance. Assurez-vous d'utiliser la dernière version de Docker Engine. Créez l'image avec --t [Image-Name]: Debug Mode pour déboguer le problème. Vérifiez l'espace disque et assurez-vous qu'il est suffisant. Désactivez SELINUX pour éviter les interférences avec le processus de construction. Demandez de l'aide aux plateformes communautaires, fournissez Dockerfiles et créez des descriptions de journaux pour des suggestions plus spécifiques.

Quelle configuration de l'ordinateur est requise pour VScode Quelle configuration de l'ordinateur est requise pour VScode Apr 15, 2025 pm 09:48 PM

Vs Code Système Exigences: Système d'exploitation: Windows 10 et supérieur, MacOS 10.12 et supérieur, processeur de distribution Linux: minimum 1,6 GHz, recommandé 2,0 GHz et au-dessus de la mémoire: minimum 512 Mo, recommandée 4 Go et plus d'espace de stockage: Minimum 250 Mo, recommandée 1 Go et plus d'autres exigences: connexion du réseau stable, xorg / wayland (Linux) recommandé et recommandée et plus

See all articles