Maison >Java >JavaBase >Qu'est-ce qu'un fil de discussion en Java

Qu'est-ce qu'un fil de discussion en Java

(*-*)浩
(*-*)浩original
2019-11-13 13:45:432912parcourir

Thread fait référence à un processus d'exécution dans un processus. Un processus peut exécuter plusieurs threads. Par exemple, le processus java.exe peut exécuter de nombreux threads. Les threads entrent toujours dans un processus et plusieurs threads d'un processus partagent la mémoire du processus.

Qu'est-ce qu'un fil de discussion en Java

Un thread en Java fait référence à une instance de la classe java.lang.Thread ou à l'exécution d'un thread. Utilisez l'interface java.lang.Thread ou java.lang.Runnable pour écrire du code permettant de définir, d'instancier et de démarrer de nouveaux threads. (Apprentissage recommandé : Cours Java )

Chaque thread en Java a une pile d'appels Même s'il n'est pas créé dans le programme, le thread s'exécute en arrière-plan. La méthode main() s’exécute dans un thread, appelé thread principal. Une fois qu'un nouveau thread est créé, une nouvelle pile d'appels est créée. ​

Les fils de discussion sont divisés en deux catégories : Les fils de discussion des utilisateurs et les fils de discussion en attente. Lorsque tous les threads utilisateur ont fini de s'exécuter, la JVM s'arrête automatiquement. Cependant, le thread en attente n'est pas indépendant de la JVM. Le thread en attente est généralement créé par le système d'exploitation ou l'utilisateur.

Les avantages que nous apportent les threads

Si les threads peuvent être utilisés de manière rationnelle, les coûts de développement et de maintenance seront réduits, et les performances des applications complexes pourront même être améliorées . Par exemple, dans les applications GUI, les événements peuvent être mieux traités grâce à la nature asynchrone des threads ; dans les programmes de serveur d'applications, plusieurs threads peuvent être établis pour gérer les demandes des clients.

Les threads peuvent même simplifier la mise en œuvre de machines virtuelles. Par exemple, le garbage collector d'une machine virtuelle Java (JVM) s'exécute généralement dans un ou plusieurs threads. Par conséquent, l'utilisation de threads améliorera nos applications dans les cinq aspects suivants :

1. Utiliser pleinement les ressources du processeur

La plupart des ordinateurs dans le monde n'ont désormais qu'un seul processeur. . Il est donc particulièrement important d’utiliser pleinement les ressources du processeur. Lors de l'exécution d'un programme monothread, le processeur peut être inactif alors que le programme est bloqué. Cela entraînera un gaspillage important de ressources informatiques.

L'utilisation du multi-threading dans un programme peut exécuter d'autres threads lorsqu'un thread est en veille ou bloqué et que le processeur est inactif. De cette façon, il est difficile pour le processeur de rester inactif. Les ressources du processeur sont donc pleinement utilisées.

2. Modèle de programmation simplifié

Si le programme n'effectue qu'une seule tâche, écrivez simplement un programme monothread et écrivez le code selon les étapes pour effectuer la tâche. tâche C'est tout. Mais pour effectuer plusieurs tâches, si vous utilisez toujours un seul thread, vous devez déterminer dans le programme si et quand chaque tâche doit être exécutée. Par exemple, il affiche les heures, les minutes et les secondes d'une horloge.

Si vous utilisez un seul fil, vous devez juger le temps de rotation et l'angle de ces trois pointeurs un à un dans la boucle. Si trois threads sont utilisés pour gérer l’affichage de ces trois pointeurs, cela signifie alors effectuer une tâche distincte pour chaque thread. Cela aide les développeurs à comprendre et à maintenir le programme.

3. Simplifiez le traitement des événements asynchrones

Lorsqu'une application serveur reçoit différentes connexions client, la manière la plus simple de la gérer est de se connecter pour chaque client Créer un thread . Le thread d'écoute est alors toujours chargé d'écouter les requêtes du client.

Si ce type d'application est traité par un seul thread, lorsque le thread d'écoute reçoit une requête client, il commence à lire les données envoyées par le client. Après avoir lu les données, la méthode de lecture est bloquée. état, c'est-à-dire également que ce thread ne pourra plus écouter les demandes des clients.

Pour gérer plusieurs requêtes clients dans un seul thread, vous devez utiliser des connexions Socket non bloquantes et des E/S asynchrones. Cependant, l'utilisation d'E/S asynchrones est plus difficile à contrôler et plus sujette aux erreurs que l'utilisation d'E/S synchrones. Par conséquent, les événements asynchrones tels que les requêtes multiples peuvent être gérés plus facilement grâce au multithreading et aux E/S synchrones.

4. Rendre l'interface graphique plus efficace

Lorsque vous utilisez un seul thread pour gérer les événements de l'interface graphique, vous devez utiliser une boucle pour rechercher les événements de l'interface graphique qui peuvent se produire à tout moment. time. Dans la boucle En plus d'analyser les événements de l'interface graphique en interne, il doit également exécuter d'autres codes de programme. Si le code est trop long, les événements de l'interface graphique seront "gelés" jusqu'à ce que le code soit exécuté.

Dans les frameworks GUI modernes (tels que SWING, AWT et SWT), un thread de répartition d'événements (EDT) distinct est utilisé pour analyser les événements GUI. Lorsque nous appuyons sur un bouton, la fonction d'événement de clic du bouton sera appelée dans ce fil de répartition d'événements.

Étant donné que la tâche d'EDT est uniquement d'analyser les événements de l'interface graphique, la réponse aux événements de cette manière est très rapide.

5. Économisez des coûts

Il existe généralement trois façons d'améliorer l'efficacité d'exécution du programme :

(1 ) Augmentez le nombre de processeurs de l'ordinateur.

(2) Démarrez plusieurs processus pour un programme

(3) Utilisez le multi-threading dans le programme.

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
Article précédent:qu'est-ce que Java statiqueArticle suivant:qu'est-ce que Java statique