Méthodes appelées de manière asynchrone par @Async en Java
Avant-propos
Appel asynchrone et appel synchrone
Appel synchrone : Exécuter séquentiellement, exécuter à nouveau l'appel suivant en renvoyant le résultat de l'appel
Appel asynchrone : Exécuter le prochain appel sans attendre le return result Appel
1. Explication @Async
Le code d'annotation de @Async est le suivant :
@Target({ElementType.TYPE, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface Async { String value() default ""; }
Les annotations peuvent être utilisées dans les types et les méthodes
La valeur est définie par valeur et la valeur par défaut est vide
Généralement, cette annotation doit correspondre à @EnableAsync , le code d'origine est le suivant
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Import({AsyncConfigurationSelector.class}) public @interface EnableAsync { Class<? extends Annotation> annotation() default Annotation.class; boolean proxyTargetClass() default false; AdviceMode mode() default AdviceMode.PROXY; int order() default Integer.MAX_VALUE; }
Principalement placé dans la classe de démarrage via cette annotation pour le démarrage de la configuration
Ajoutez ce qui suit dans la classe de démarrage :
@SpringbootApplication @EnableAsync public class Application{ public static void main(String[] args){ SrpingApplication.run(Application.class, args); } }
Utilisation
2.2.1 Appel synchrone
Le résultat de la fonction ne peut être exécuté qu'à partir de l'appel jusqu'au retour Une étape, appelée appel synchrone
Code de la couche de service :
public class Service{ public void test01() throws InterruptedException{ Thread.sleep(5000); System.out.println("保存日志"); } }
Module de code de la couche de contrôle :
public class Controler{ @Autowired private Service service; @GetMapping("/test") public String getTest(){ try{ System.out.println("开始"); service.test01(); System.out.println("结束"); }catch(InterruptedException e){ e.prinStackTrace(); } } }
Après avoir démarré via la classe de démarrage de Springboot
Le résultat est le suivant :
Début
//Il s'agit d'attendre 5 secondes, Le terminal n'est ni affiché ni fermé
Fin
2.2 Appel asynchrone
Appel asynchrone, la fonction en cours d'exécution peut s'exécuter l'étape suivante sans attendre le résultat de retour
Code de la couche de service :
Ajout principal de l'annotation @Async pour identifier cette méthode
public class Service{ @Async public void test01() throws InterruptedException{ Thread.sleep(500); System.out.println("保存日志"); } }
Module de code de la couche de contrôle :
Démarrez @EnableAsync en appelant la fonction de couche de service
public class Controler{ @Autowired private Service service; @GetMapping("/test") public String getTest(){ try{ System.out.println("开始"); service.test01(); System.out.println("结束"); }catch(InterruptedException e){ e.prinStackTrace(); } } }
et en ajoutant annotations à la classe de démarrage
@SpringbootApplication @EnableAsync public class Application{ public static void main(String[] args){ SrpingApplication.run(Application.class, args); } }
3. Personnaliser le pool de threads
Pour des connaissances de base sur le pool de threads, veuillez consulter mon article précédent :
Comment fermer correctement les threads et les pools de threads en Java (la pratique du code inclut l'analyse du code source )
Analyse détaillée de la façon de créer un pool de threads Java (complet)
Si vous ne spécifiez pas de pool de threads, le pool de threads par défaut utilisé est SimpleAsyncTaskExecutor (quand une tâche arrive, créez simplement un thread. La création continue de threads entraînera le CPU trop élevé et provoque un MOO). Le pool de threads intégré présente généralement des inconvénients. Il est généralement recommandé d'utiliser ThreadPoolExecutor (effacer les ressources du pool de threads et éviter les risques)
Les détails sont les suivants :
-
newFixedThreadPool : Même si le nombre de threads est fixe, la file d'attente des tâches est toujours illimitée (le nombre maximum de threads ne sera créé que lorsque la file d'attente est pleine), cela provoquera donc un MOO
newCachedThreadPool : Il n'y a pas de pool supérieur limite pour le nombre maximum de threads, et un grand nombre de threads sont créés. Facile à geler ou directement OOM
La configuration du pool de threads peut être ajustée via un pool de threads personnalisé pour une meilleure utilisation des ressources
@Async Cette annotation recherche le Interface AsyncConfigurer (la classe d'implémentation est AsyncConfigurerSupport, la configuration et les méthodes par défaut sont vides), de sorte que l'interface peut être remplacée pour spécifier le pool de threads.
En implémentant l'interface AsyncConfigurer
Hériter AsyncConfigurerSupport
Custom TaskExecutor (en remplacement de l'exécuteur de tâches intégré)
La troisième méthode :
Définir des pools de threads dans l'application Variable .xml
thread.core.size=16 thread.max.size=16 thread.queue.size=30 thread.prefix=xx-
Le pool de threads personnalisés est le suivant
import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import java.util.concurrent.ThreadPoolExecutor; @Configuration public class ThreadPoolConfig { // 线程名称前缀 @Value("${thread.prefix}") private String threadPrefix; // 核心线程数 @Value("${thread.core.size}") private int coreSize; // 最大线程数 @Value("${thread.max.size}") private int maxSize; // 队列长度 @Value("${thread.queue.size}") private int queueSize; // 通过bean注解注入 @Bean("xx") public ThreadPoolTaskExecutor taskExecutor() { ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor(); //设置线程池参数信息 taskExecutor.setCorePoolSize(coreSize); taskExecutor.setMaxPoolSize(maxSize); taskExecutor.setQueueCapacity(queueSize); taskExecutor.setThreadNamePrefix(threadPrefix); taskExecutor.setWaitForTasksToCompleteOnShutdown(true); taskExecutor.setAwaitTerminationSeconds(30); //修改拒绝策略为使用当前线程执行 taskExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); //初始化线程池 taskExecutor.initialize(); return taskExecutor; } }
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 du générateur de nombres aléatoires en Java. Nous discutons ici des fonctions en Java avec des exemples et de deux générateurs différents avec d'autres exemples.

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
