Processus et threads Linux : 1. La différence réside dans les différentes méthodes de gestion des ressources du système d'exploitation. Les processus ont des espaces d'adressage indépendants, mais il n'y a pas d'espace d'adressage séparé entre les threads ; 2. La connexion est qu'un thread peut créer et annuler un autre thread ; , Plusieurs threads dans le même processus peuvent s'exécuter simultanément, et les threads ne sont que des chemins d'exécution différents dans un processus.
L'environnement d'exploitation de ce tutoriel : système linux7.3, ordinateur Dell G3.
Contact :
Un thread peut créer et annuler un autre thread dans le même processus peut s'exécuter simultanément. un thread est un concept plus proche d'un corps d'exécution. Il peut partager des données avec d'autres threads du même processus, mais possède son propre espace de pile et une séquence d'exécution indépendante.
Différence : La principale différence entre les processus et les threads est qu'il s'agit de manières différentes de gérer les ressources du système d'exploitation. Le processus dispose d'un espace d'adressage indépendant. Après le crash d'un processus, cela n'affectera pas les autres processus en mode protégé, et les threads sont simplement des chemins d'exécution différents dans un processus. Les threads ont leurs propres piles et variables locales, mais il n'y a pas d'espace d'adressage séparé entre les threads. La mort d'un thread équivaut à la mort de l'ensemble du processus. Par conséquent, les programmes multi-processus sont plus robustes que les programmes multi-thread. lors du changement de processus, cela prend beaucoup de temps. Les ressources sont plus importantes et l'efficacité est moindre. Mais pour certaines opérations simultanées qui nécessitent l'exécution et le partage simultanés de certaines variables, seuls les threads, et non les processus, peuvent être utilisés.
Développer les connaissancesDans de nombreux manuels classiques sur les systèmes d'exploitation, un processus est toujours défini comme une instance d'exécution d'un programme. Il n'exécute rien, mais ne maintient que diverses ressources requises par l'application. les véritables entités d’exécution.
Pour qu'un processus accomplisse une certaine quantité de travail, le processus doit contenir au moins un thread.
Processus, intuitivement parlant, une fois le programme enregistré sur le disque dur exécuté, un corps de mémoire indépendant sera formé dans l'espace mémoire. Ce corps de mémoire a son propre espace d'adressage et son propre tas. l’unité affiliée est le système d’exploitation.
Les threads existent dans les processus et sont les plus petites unités de planification et d'exécution par le système d'exploitation. Pour faire simple, les threads fonctionnent. color{red}{Les fils sont juste pour le travail. }Les fils de discussion sont ce qui fait le travail.
Un processus est un programme doté de certaines fonctions indépendantes. Il s'agit d'une activité exécutée sur un certain ensemble de données. Un processus est une unité indépendante d'allocation et de planification des ressources dans le système. Un thread est une entité d'un processus et l'unité de base de la planification et de la répartition du processeur. C'est une unité de base qui est plus petite qu'un processus et peut s'exécuter de manière indépendante. Le thread lui-même ne possède pas de ressources système, seulement quelques ressources essentielles à son exécution (comme un compteur de programme, un ensemble de registres et une pile), mais il peut partager toutes les ressources possédées par le processus avec d'autres threads qui appartiennent au même processus.
Si le processus est un gestionnaire de ressources, chargé de demander des ressources au propriétaire, alors le fil est le travailleur acharné. Si le processus est un gestionnaire de ressources, chargé de demander des ressources au propriétaire, alors le thread est le travailleur acharné. Une femme de ménage doit effectuer un travail qui nécessite au moins un coolie. C'est-à-dire qu'un processus contient au moins un thread et peut également contenir plusieurs threads. Si les coolies veulent travailler, ils doivent s'appuyer sur la femme de ménage, donc un fil doit appartenir à un certain processus. Le processus possède son propre espace d'adressage et les threads utilisent l'espace d'adressage du processus. En d'autres termes, les threads ont accès aux ressources du processus, telles que les tas, les piles, les zones de stockage statiques, etc.
Le thread est un prolétariat, mais lorsque le prolétariat fonctionne, il doit avoir son propre outil de travail, c'est la pile. Le thread a sa propre pile. Cette pile utilise toujours l'espace d'adressage du processus, mais cet espace l'est. marqué par le fil pour la pile. Chaque thread aura sa propre pile privée, à laquelle les autres threads ne pourront pas accéder.
Ce que le processus conserve, ce sont les ressources (ressources statiques) contenues dans le programme, telles que : l'espace d'adressage, l'ensemble de descripteurs de fichiers ouverts, l'état du système de fichiers, le gestionnaire de traitement du signal, etc.
Les ressources liées à l'exécution (ressources dynamiques) ) maintenus par les ressources du thread), tels que : la pile en cours d'exécution, les informations de contrôle liées à la planification, l'ensemble de signaux à traiter, etc. ;
Les threads et les processus ont leurs propres avantages et inconvénients lors de leur utilisation : la surcharge d'exécution du thread est faible, mais cela n’est pas propice à la gestion et à la protection des ressources ; et le processus est exactement le contraire.
Apprentissage recommandé : Tutoriel vidéo Linux
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!