Maison  >  Article  >  Java  >  Comment utiliser la fonction ScheduledThreadPoolExecutor en Java pour la planification de tâches planifiées

Comment utiliser la fonction ScheduledThreadPoolExecutor en Java pour la planification de tâches planifiées

王林
王林original
2023-06-26 17:48:101479parcourir

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

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

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

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

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

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

  1. 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 :

  1. La tâche à exécuter
  2. Le délai de la première exécution de la tâche
  3. Tâche. intervalle d'exécution Le temps
  4. 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 :

  1. La tâche à exécuter
  2. Le délai de la première exécution de la tâche
  3. L'unité du temps de retard
  4. Délai pour terminer l'exécution de la tâche
  5. 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 :

  1. Peut exécuter plusieurs tâches en même temps
  2. Possibilité de gérer le nombre de threads dans le pool de threads
  3. Peut ajuster de manière flexible le temps d'exécution des tâches
  4. Fournit une puissante fonction de planification qui permet aux tâches d'être programmé à certains intervalles de temps Exécution

Inconvénients :

  1. Impossible d'obtenir l'état et les résultats des tâches de manière asynchrone
  2. 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!

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