亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Table des matières
Qu'est-ce que le cadre de l'exécuteur?
Pourquoi utiliser l'exécuteur au lieu de nouveau thread ()?
Types de pool de threads communs (créé via la classe d'outils exécuteurs)
Explication détaillée des composants clés
1. Paramètres centraux de ThreadpoolExecutor
2. Sélection de la file d'attente des taches
3. Gestionnaire d'exécution rejeté
Comment soumettre des taches: Runnable vs Callable
Comment fermer élégamment la piscine de fil?
Résumé: recommandations de meilleures pratiques
Maison Java javaDidacticiel Concurrence Java dans la pratique: le cadre de l'exécuteur

Concurrence Java dans la pratique: le cadre de l'exécuteur

Jul 31, 2025 am 01:52 AM
java concurrent

Executor Framework est un outil de concurrence en Java pour simplifier la gestion des threads et la planification des taches, et son noyau est de découpler la soumission des taches à partir de l'exécution. 1. Les raisons de l'utilisation de l'exécuteur au lieu de nouveau thread () incluent d'éviter les ressources hors de contr?le, d'améliorer les performances, d'implémenter la réutilisation du thread et la gestion unifiée; 2. Les principales interfaces sont l'exécuteur exécuteur et l'exécution de l'interface d'extension, qui prend en charge la soumission des taches, la gestion du cycle de vie et les résultats futurs de retour; 3. Les types de piscines de fil conducteur incluent NewFixEdThreadpool, NewCachedThreadpool, NewsingLethreAdExecutor et NewscheduLedThreadPool, qui conviennent à différents scénarios; 4. Il est recommandé de créer manuellement ThreadPoolExecutor et de définir clairement CorePoolSize, MaximumpoolSize, KeepaliveTime, WorkQueue, ThreadFactory et RejectEdExecutionHandler paramètres; 5. La file d'attente des taches doit être prioritaire aux files d'attente délimitées telles que ArrayBlockingQueue pour empêcher l'OOM; 6. La politique de rejet comprend une abordation, Callersepolicy, Discardpolicy et DiskeroldestPolicy, qui devrait être sélectionnée selon les besoins de l'entreprise; 7. Lors de la soumission de taches, vous pouvez utiliser Runnable (pas de valeur de retour) ou callable (avec valeur de retour) pour obtenir des objets futurs via la méthode de soumission; 8. Lors de la fermeture du pool de threads, vous devez d'abord appeler Shutdown (), puis combiner awittermination () et shutdownnow () pour assurer un temps d'arrêt élégant; 9. Les meilleures pratiques incluent l'évitement de l'utilisation des méthodes de raccourci des exécuteurs, des paramètres de configuration explicites, du pool de threads nommé, un réglage raisonnable du nombre de threads, du pool de threads de cl?ture en temps opportun et de la gestion des exceptions dans Runnable. L'utilisation correcte du cadre de l'exécuteur peut éviter efficacement les problèmes d'épuisement des ressources et de performances et est la base de la création d'applications Java à haute concurrence.

Concurrence Java dans la pratique: le cadre de l'exécuteur

La programmation simultanée en Java est souvent un mal de tête, et le livre "Java Concurrence in Practice" est connu sous le nom de "Bible" de la programmation simultanée. L'explication de l'exécuteur exécuteur (Frame d'exécuteur) est un lien clé pour comprendre le développement multi-thread Java moderne. Il nous permet de nous débarrasser du lourd et du risque de threads (threads) de fonctionnement directement et d'utiliser à la place des abstractions de niveau supérieur pour gérer l'exécution des taches.

Concurrence Java dans la pratique: le cadre de l'exécuteur

Qu'est-ce que le cadre de l'exécuteur?

Le cadre exécuteur est un ensemble d'API introduit dans Java 5 pour simplifier la gestion des threads et la planification des taches, et le noyau est situé dans java.util.concurrent . Son objectif de conception est de découpler la soumission des taches de l'exécution des taches .

L'interface la plus principale est Executor :

Concurrence Java dans la pratique: le cadre de l'exécuteur
 Exécuteur de l'interface publique {
    void EXECUTE (Commande Runnable);
}

Ne le regardez pas simplement, il y a une puissante idée de conception derrière: vous n'avez qu'à soumettre la tache, et comment l'exécuter (quel thread est utilisé, qu'il soit réutilisé, ou s'il est asynchrone) est déterminé par la classe d'implémentation.

Ce qui est plus couramment utilisé, c'est son interface d'extension: ExecutorService , qui prend en charge la gestion du cycle de vie, le résultat de retour de soumission des taches (futur), la fermeture élégante, etc.

Concurrence Java dans la pratique: le cadre de l'exécuteur

Pourquoi utiliser l'exécuteur au lieu de nouveau thread ()?

Utilisation new Thread(runnable).start() semble directement simple, mais il y a des problèmes évidents:

  • Ressources incontr?lables : chaque fois qu'une tache arrive, un fil est créé et les ressources système sont rapidement épuisées.
  • Manque de gestion : le nombre de concurrence ne peut pas être limité, le nombre de threads ne peut pas être réutilisé et la surveillance ne peut pas être unifiée.
  • Performances médiocres : des frais généraux élevés pour la création de filetages et la destruction.

Les avantages de l'utilisation du cadre de l'exécuteur comprennent:

  • ? Réutilisation du thread (via le pool de threads)
  • ? Contr?lez le nombre de
  • ? Améliorez la vitesse de réponse (la tache est exécutée directement lorsqu'il s'agit, sans attendre la création de thread)
  • ? Gestion des exceptions unifiées et gestion des ressources
  • ? Prise en charge des taches planifiées et périodiques (ScheduleDExEcutorService)

Types de pool de threads communs (créé via la classe d'outils exécuteurs)

Bien que Executors fournissent une méthode pratique, il est recommandé de créer manuellement ThreadPoolExecutor pour clarifier les paramètres de la production réelle. Mais comprenez d'abord les types communs:

Type de piscine de fil illustrer Scénarios applicables
newFixedThreadPool(n) Pool de threads de taille fixe, jusqu'à N Threads fonctionne Charge stable et volume de tache prévisible
newCachedThreadPool() Pool de threads cacheable, threads inactifs recyclés en 60 secondes, créé à la demande Les taches asynchrones à court terme sont nombreuses et les taches sont très inattendues
newSingleThreadExecutor() Piscine unique pour assurer l'exécution en série des taches Taches qui doivent être exécutées séquentiellement
newScheduledThreadPool(n) Pool de thread qui prend en charge les taches de synchronisation / périodiques Taches de synchronisation telles que la détection du rythme cardiaque

Exemple:

 ExecutorService exécutor = exécutor.NewFixEdThreadPool (4);

pour (int i = 0; i <10; i) {
    EMECTOR.EXECUTE (() -> {
        System.out.println ("Tache exécutée par" thread.currentThread (). GetName ());
    });
}

// N&#39;oubliez pas de fermer EMIRMETOR.SHUTDOWN ();

Explication détaillée des composants clés

1. Paramètres centraux de ThreadpoolExecutor

Il est plus s?r de créer un pool de threads manuellement, avec les paramètres clés comme suit:

 Nouveau threadpoolexecutor (
    CorePoolSize, // Nombre de threads de base (résident)
    MaximumpoolSize, // Nombre maximum de threads keepalivetime, // unité de temps de survie sans fil non coré, // unité de temps workqueue, // file d&#39;attente de tache (comme LinkedBlockingQueue, ArrayBlockingQueue)
    ThreadFactory, // Factory de création de threads (personnalisable)
    RejectEdExecutionHandler // Rejeter la politique);

?? Remarque: Executors.newFixedThreadPool() utilise une file d'attente non liée ( LinkedBlockingQueue ), qui peut provoquer un débordement de mémoire (OOM). Utilisez-le avec prudence dans l'environnement de production.

2. Sélection de la file d'attente des taches

  • ArrayBlockingQueue : Fitre délimitée, recommandée, empêcher l'épuisement des ressources
  • LinkedBlockingQueue : file d'attente illimité, facile à remplir la mémoire
  • SynchronousQueue : Aucun éléments n'est stocké, chaque insert doit attendre le retrait (convient à newCachedThreadpool)
  • PriorityBlockingQueue : prend en charge les files d'attente de taches prioritaires

3. Gestionnaire d'exécution rejeté

Lorsque le pool de threads est fermé ou que la file d'attente est pleine, la nouvelle tache est refusée. Stratégies courantes:

  • AbortPolicy : lancer RejectedExecutionException (par défaut)
  • CallerRunsPolicy : le fil qui soumet la tache elle-même (ralentit la vitesse de validation)
  • DiscardPolicy : jetez silencieusement les taches
  • DiscardOldestPolicy : jetez la tache la plus ancienne de la file d'attente et essayez de se soumettre à nouveau

Il est recommandé d'utiliser des alertes logarithmiques AbortPolicy basées sur des choix commerciaux, tels que l'utilisation de journaux abortpolicy à l'alerte, et les taches non critiques peuvent être rejetées.


Comment soumettre des taches: Runnable vs Callable

  • execute(Runnable) : pas de valeur de retour
  • submit(Runnable) : renvoie Future<?> , qui peut être utilisé pour déterminer s'il est terminé
  • submit(Callable<T>) : Retour Future<T> pour obtenir la valeur de retour ou l'exception
 Futur <Integer> futur = exécutor.sumit (() -> {
    retour 42;
});

Résultat entier = futur.get (); // bloque et attendez le résultat

Vous pouvez également utiliser invokeAll() pour soumettre plusieurs callables en lots, ou invokeAny() pour retourner le premier résultat terminé.


Comment fermer élégamment la piscine de fil?

Direct shutdown() ne suffit pas, il est recommandé:

 exécuteur.shutdown (); // Aucune nouvelle tache n&#39;est re?ue, essayez {
    if (! exécutor.awampitring (60, timeunit.seconds)) {
        exécuteur.shutdownNow (); // Essayez d&#39;interrompre la tache d&#39;exécution}
} catch (InterruptedException e) {
    exécuteur.shutdownNow ();
    Thread.currentThread (). Interrupt ();
}

Cela garantit que le pool de threads a suffisamment de temps pour effectuer les taches existantes avant la sortie de l'application.


Résumé: recommandations de meilleures pratiques

  • ? évitez d'utiliser la méthode de raccourci Executors pour créer des pools de threads (en particulier les files d'attente illimitées)
  • ? Utilisez ThreadPoolExecutor pour configurer explicitement les paramètres pour clarifier la taille de la file d'attente et rejeter la stratégie
  • ? Nommez le pool de threads (via ThreadFactory ) pour faciliter le dépannage
  • ? Réglez corePoolSize et maxPoolSize raisonnables, combiné avec un ajustement de mesure de la pression
  • ? N'oubliez pas de fermer le pool de threads pour éviter la fuite des ressources
  • ? Gestion des exceptions: Runnable a besoin d'essayer une prise en interne en interne, sinon l'exception "dispara?tra"

Fondamentalement, c'est tout. L'exécuteur Framework résume la gestion complexe des threads dans une interface concise et est la pierre angulaire de la programmation simultanée Java moderne. La compréhension non seulement d'écrire du code plus robuste, mais évitera également de nombreux problèmes en ligne tels que "fil complet", "CPU en flèche" et "débordement de mémoire".

Pas compliqué, mais il est facile d'ignorer les détails.

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 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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

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.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

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)

Construire des API RESTful à Java avec Jakarta EE Construire des API RESTful à Java avec Jakarta EE Jul 30, 2025 am 03:05 AM

Setupamaven / gradleprojectwithjax-rsDependces likejersey; 2.CreateArestResourceUsingannotationsSuchas @ pathand @ get; 3.ConfigureTheApplicationViaApplicationsUbclassorweb.xml; 4.AddjacksonforjsonBindingByCludingJersey-Media-Json-Jackson; 5.DeploEp

Un guide du développeur à Maven pour la gestion de projet Java Un guide du développeur à Maven pour la gestion de projet Java Jul 30, 2025 am 02:41 AM

Maven est un outil standard pour la gestion et la construction de projet Java. La réponse réside dans le fait qu'il utilise pom.xml pour normaliser la structure du projet, la gestion des dépendances, l'automatisation du cycle de vie de la construction et les extensions de plug-in; 1. Utilisez pom.xml pour définir GroupID, Arfactive, version et dépendances; 2. Commandes Master Core telles que MvnClean, compiler, tester, package, installer et déploier; 3. Utiliser la fonction de dépendance et les exclusions pour gérer les versions et les conflits de dépendance; 4. Organisez de grandes applications via la structure du projet multi-modules et sont gérées uniformément par le POM parent; 5

Exemple de bascule du mode sombre CSS Exemple de bascule du mode sombre CSS Jul 30, 2025 am 05:28 AM

Tout d'abord, utilisez JavaScript pour obtenir les préférences du système utilisateur et les paramètres de thème stockés localement et initialiser le thème de la page; 1. La structure HTML contient un bouton pour déclencher la commutation du sujet; 2. CSS utilise: Root pour définir des variables de thème brillantes, la classe de mode. Dark définit les variables de thème sombres et applique ces variables via var (); 3. JavaScript détecte préfère-Color-Scheme et lit LocalStorage pour déterminer le thème initial; 4. Communiquez la classe en mode noir sur l'élément HTML lorsque vous cliquez sur le bouton et enregistre l'état actuel vers LocalStorage; 5. Tous les changements de couleur sont accompagnés d'une animation de transition de 0,3 seconde pour améliorer l'utilisateur

Exemple de décorateur de propriété Python Exemple de décorateur de propriété Python Jul 30, 2025 am 02:17 AM

@Property Decorator est utilisé pour convertir les méthodes en propriétés pour implémenter le contr?le de lecture, de réglage et de suppression des propriétés. 1. Utilisation de base: définissez des attributs en lecture seule via @Property, tels que la zone calculée en fonction du rayon et accédé directement; 2. Utilisation avancée: utilisez @ name.setter et @ name.deleter pour implémenter les opérations de vérification et de suppression de l'attribut d'attribut; 3. Application pratique: effectuer la vérification des données dans les setters, tels que BankAccount pour s'assurer que le solde n'est pas négatif; 4. Spécification de dénomination: les variables internes sont préfixées, les noms de méthode de propriété sont cohérents avec les attributs et le contr?le d'accès unifié est utilisé pour améliorer la sécurité et la maintenabilité du code.

Comment utiliser Java MessagediGest pour le hachage (MD5, SHA-256)? Comment utiliser Java MessagediGest pour le hachage (MD5, SHA-256)? Jul 30, 2025 am 02:58 AM

Pour générer des valeurs de hachage à l'aide de Java, il peut être implémenté via la classe MessagediGest. 1. Obtenez une instance de l'algorithme spécifié, tel que MD5 ou SHA-256; 2. Appelez la méthode .update () à transmettre les données à chiffrer; 3. Appelez la méthode .digest () pour obtenir un tableau d'octets de hachat; 4. Convertir le tableau d'octets en une cha?ne hexadécimale pour la lecture; Pour les entrées telles que les fichiers gros, lisez dans des morceaux et appelez .Update () plusieurs fois; Il est recommandé d'utiliser SHA-256 au lieu de MD5 ou SHA-1 pour assurer la sécurité.

Exemple de menu déroulant CSS Exemple de menu déroulant CSS Jul 30, 2025 am 05:36 AM

Oui, un menu déroulant CSS commun peut être implémenté via Pure HTML et CSS sans JavaScript. 1. Utilisez des ul imbriqués et Li pour construire une structure de menu; 2. Utilisez le: Hover Pseudo-Class pour contr?ler l'affichage et la cachette du contenu déroulant; 3. Position définie: relative pour le parent li, et le sous-menu est positionné en utilisant la position: absolue; 4. Le sous-menu défaut par défaut: Aucun, qui devient affichage: Block lorsqu'il a survolé; 5. Le tir-down à plusieurs niveaux peut être réalisé grace à la nidification, combinée à la transition, et à l'ajout d'animations fondues, et adaptées aux terminaux mobiles avec des requêtes multimédias. La solution entière est simple et ne nécessite pas de prise en charge JavaScript, qui convient au grand

Exemple de cha?ne de date d'analyse Python Exemple de cha?ne de date d'analyse Python Jul 30, 2025 am 03:32 AM

Utilisez dateTime.Strptime () pour convertir les cha?nes de date en objet DateTime. 1. Utilisation de base: Parse "2023-10-05" comme objet DateTime via "% y-% m-% d"; 2. prend en charge plusieurs formats tels que "% m /% d /% y" pour analyser les dates américaines, "% d /% m /% y" pour analyser les dates britanniques, "% b% d,% y% i:% m% p" pour analyser le temps avec AM / PM; 3. Utilisez dateUtil.parser.parse () pour déduire automatiquement les formats inconnus; 4. Utiliser .d

Comment convertir un tableau en une liste en Java? Comment convertir un tableau en une liste en Java? Jul 30, 2025 am 01:54 AM

La conversion d'un tableau en une liste en Java nécessite de sélectionner des méthodes basées sur le type de données et les exigences. ① Utilisez des arrays.aslist () pour convertir rapidement un tableau d'objets (tel que String []) en une liste de taille fixe, mais les éléments ne peuvent pas être ajoutés ou supprimés; ② Si vous avez besoin d'une liste mutable, vous pouvez encapsuler le résultat de Arrays.aslist () via le constructeur ArrayList; ③ Pour les tableaux de type de base (tels que int []), vous devez utiliser la conversion StreamAPI, tels que Arrays.Stream (). Boxed (). Collect (Collectors.tolist ()); ④ Les notes comprennent d'éviter les tableaux nuls, la distinction des types de base des types d'objets et les colonnes de retour explicitement

See all articles