


Comment utiliser la fonction ScheduledThreadPoolExecutor en Java pour la planification de tâches planifiées
À mesure que la complexité des systèmes logiciels continue d'augmenter, de plus en plus de tâches asynchrones sont impliquées dans le système. Comment planifier efficacement ces tâches asynchrones est une compétence nécessaire. En Java, vous pouvez utiliser ScheduledThreadPoolExecutor pour la planification de tâches planifiées. Cet article présentera l'utilisation de base de ScheduledThreadPoolExecutor et comment l'utiliser pour implémenter la planification planifiée de tâches asynchrones.
ScheduledThreadPoolExecutor est une classe intégrée à Java qui implémente la planification de tâches planifiées. Il hérite de la classe ThreadPoolExecutor, possède toutes les caractéristiques d'un pool de threads et peut exécuter des tâches spécifiées en fonction de l'intervalle de temps ou du délai spécifié.
Pour utiliser ScheduledThreadPoolExecutor pour planifier des tâches planifiées, vous devez remplir les conditions de base suivantes :
- Créer un objet ScheduledThreadPoolExecutor
Lors de la création d'un objet ScheduledThreadPoolExecutor, vous devez spécifier la taille du pool de threads. La taille du pool de threads détermine le nombre de tâches pouvant être exécutées simultanément et le nombre de ressources requises par les tâches. Lors de la création d'un objet, vous pouvez spécifier deux paramètres, corePoolSize et maximumPoolSize, qui représentent respectivement la taille du pool de threads principal et la taille du pool de threads maximum. Ici, nous pouvons les définir sur des valeurs égales, c'est-à-dire utiliser un pool de threads de taille fixe.
- Définir des tâches exécutables ou appelables
Les tâches de ScheduledThreadPoolExecutor sont implémentées sur la base des interfaces Runnable et Callable de la bibliothèque de classes Java. Lors de la définition d'une tâche, vous pouvez choisir Runnable ou Callable, et vous pouvez choisir la méthode d'implémentation correspondante en fonction des besoins réels.
- Spécifiez la méthode d'exécution de la tâche
Dans ScheduledThreadPoolExecutor, vous pouvez spécifier la méthode d'exécution de la tâche. Vous avez le choix entre deux manières : l'une consiste à utiliser la méthode planningAtFixedRate(), l'autre consiste à utiliser la méthode planningWithFixedDelay(). La différence entre ces deux méthodes est que la méthode planningAtFixedRate() exécute la tâche selon un intervalle de temps fixe, tandis que la méthode planningWithFixedDelay() calcule le temps d'exécution de la tâche suivante en fonction du temps d'exécution de la tâche.
Ci-dessous, nous présenterons ces étapes en détail avec le code.
- Création d'un objet ScheduledThreadPoolExecutor
Voici l'exemple de code de base pour créer un objet ScheduledThreadPoolExecutor :
ScheduledExecutorService executor = Executors.newScheduledThreadPool(1);
Dans ce code, nous créons un pool de threads de taille 1 à l'aide de la classe utilitaire Executors de Java. Étant donné que ScheduledThreadPoolExecutor hérite de la classe ThreadPoolExecutor, nous pouvons utiliser les méthodes habituelles liées au pool de threads pour gérer le pool de threads.
- Définir des tâches exécutables ou appelables
Dans ScheduledThreadPoolExecutor, vous pouvez utiliser les interfaces Runnable et Callable pour définir des tâches, telles que :
Runnable task = new Runnable() { @Override public void run() { // 任务内容 } };
ou :
Callable<String> task = new Callable<String>() { @Override public String call() throws Exception { // 任务内容 return null; } };
Comme vous pouvez le voir, la façon de définir des tâches en utilisant Runnable et Callable les interfaces sont très similaires. La seule différence est que l’interface Callable doit renvoyer une valeur, contrairement à l’interface Runnable.
- Spécifiez la méthode d'exécution de la tâche
Selon l'introduction précédente, ScheduledThreadPoolExecutor fournit deux méthodes d'exécution de tâche : planningAtFixedRate() et planningWithFixedDelay(). Ce qui suit décrit comment utiliser respectivement ces deux méthodes.
scheduleAtFixedRate()
Utilisez la méthode planningAtFixedRate() pour exécuter une tâche fixe. Elle reçoit 4 paramètres, qui sont :
- La tâche à exécuter
- Le délai de la première exécution de la tâche
- Tâche. intervalle d'exécution Le temps
- L'unité de l'intervalle de temps
Ce qui suit est un exemple de la méthode planningAtFixedRate() :
executor.scheduleAtFixedRate(task, 0, 1, TimeUnit.SECONDS);
Ce code signifie qu'après un délai de 0 seconde, la tâche sera exécutée toutes les 1 seconde. Le contenu de la tâche doit être implémenté dans le Runnable ou Callable préalablement défini.
scheduleWithFixedDelay()
Similaire à la méthode planningAtFixedRate(), la méthode planningWithFixedDelay() reçoit également 4 paramètres, qui sont :
- La tâche à exécuter
- Le délai de la première exécution de la tâche
- L'unité du temps de retard
- Délai pour terminer l'exécution de la tâche
- Unité du temps de retard pour terminer l'exécution de la tâche
Ce qui suit est un exemple de la méthode planningWithFixedDelay() :
executor.scheduleWithFixedDelay(task, 0, 1, TimeUnit.SECONDS);
Ce code indique que la première tâche est exécuté après un délai de 0 seconde, puis une fois l'exécution de la tâche terminée, exécutez à nouveau la tâche avec un délai de 1 seconde. Le contenu de la tâche doit être implémenté dans le Runnable ou Callable préalablement défini.
Nous avons déjà expliqué comment utiliser ScheduledThreadPoolExecutor pour planifier des tâches planifiées. Résumons les avantages et les inconvénients de ScheduledThreadPoolExecutor.
Avantages :
- Peut exécuter plusieurs tâches en même temps
- Possibilité de gérer le nombre de threads dans le pool de threads
- Peut ajuster de manière flexible le temps d'exécution des tâches
- Fournit une puissante fonction de planification qui permet aux tâches d'être programmé à certains intervalles de temps Exécution
Inconvénients :
- Impossible d'obtenir l'état et les résultats des tâches de manière asynchrone
- Impossible d'augmenter ou de diminuer dynamiquement le nombre de tâches
En résumé, ScheduledThreadPoolExecutor est un planificateur de tâches planifiées très pratique en Java, qui peut nous aider à gérer et planifier efficacement les tâches asynchrones. Dans le développement réel, nous pouvons l'utiliser en fonction des besoins spécifiques de l'entreprise et le combiner avec d'autres bibliothèques de classes Java pour répondre à des exigences de planification de tâches plus complexes.
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

Spring Boot simplifie la création d'applications Java robustes, évolutives et prêtes à la production, révolutionnant le développement de Java. Son approche "Convention sur la configuration", inhérente à l'écosystème de ressort, minimise la configuration manuelle, allo
