À 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 :
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.
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.
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.
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.
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.
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 :
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 :
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 :
Inconvénients :
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!