Maison  >  Article  >  Java  >  La différence entre les processus et les threads en Java

La différence entre les processus et les threads en Java

王林
王林original
2019-11-12 17:26:413683parcourir

La différence entre les processus et les threads en Java

Concepts de processus et de threads

Processus (la plus petite unité d'allocation de ressources) : c'est un concept dynamique qui est en compétition pour les ressources du système informatique (CPU, mémoire, IO, etc.), c'est l'unité de base pour l'allocation et la gestion des ressources lors de l'exécution de programmes exécutés simultanément.

Thread (la plus petite unité d'exécution de programme) : Il s'agit d'une unité de base qui est plus petite qu'un processus et qui s'exécute de manière indépendante. Un thread est également appelé processus léger. Il s'agit de l'unité de base de la planification et de la répartition du processeur.

Un programme doit avoir au moins un processus, et un processus doit avoir au moins un thread.

La différence entre les processus et les threads

1. Espace d'adressage : les threads d'un même processus partagent l'espace d'adressage de ce processus, tandis que les processus sont indépendants. espace ;

2. Propriété des ressources : les threads d'un même processus partagent les ressources de ce processus, telles que les E/S, la mémoire, le CPU, etc., mais les ressources entre les processus sont indépendantes ; 3 , les programmes multi-processus sont donc plus robustes que les multi-threads. Tant qu'un thread d'un programme multi-thread meurt, l'ensemble du processus mourra, mais après un crash d'un processus, cela n'affectera pas les autres processus en mode protégé. parce que le processus a son propre espace d'adressage indépendant ;

4. Lors du changement de processus, il consomme beaucoup de ressources et est très efficace. Ainsi, lorsqu’il s’agit de changements fréquents, il est préférable d’utiliser des threads plutôt que des processus. Si des opérations simultanées sont effectuées en même temps et que certaines variables doivent être partagées, les threads ne peuvent être utilisés.

5. Processus d'exécution : Le processus est équivalent à une instance d'exécution d'application, de sorte que chaque processus indépendant a une entrée pour l'exécution du programme, une séquence d'exécution séquentielle du programme et une sortie d'exécution du programme. Chaque thread est équivalent à un flux d'exécution de cette application (processus), il ne peut donc pas être exécuté indépendamment et doit dépendre de l'application (processus). L'application fournit un contrôle d'exécution à plusieurs threads

6. Threads C'est le cas. l'unité de base de la planification du processeur, mais le processus ne l'est pas ;

7. Les threads et les processus peuvent être exécutés simultanément

Avantages et inconvénients

Exécution du thread La surcharge est faible, mais elle n'est pas propice à la gestion et à la protection des ressources. Les threads peuvent être exécutés sur des machines SMP (Symmetric Multi-Processing) (systèmes multi-CPU).

La surcharge d'exécution des processus est élevée, mais elle permet de très bien gérer et protéger les ressources.

Tutoriel recommandé :

Tutoriel Java

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!

Déclaration:
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