Maison > Java > javaDidacticiel > Comment gérer le blocage dans le pool de threads Java ?

Comment gérer le blocage dans le pool de threads Java ?

王林
Libérer: 2023-05-06 19:28:07
avant
1206 Les gens l'ont consulté

Explication

1. L'impasse fait référence au phénomène de congestion provoqué par la concurrence pour les ressources ou la communication mutuelle entre deux ou plusieurs processus au cours du processus de mise en œuvre, ils ne peuvent pas avancer.

Instance de blocage du pool de threads

2. Solution : développez le pool de threads et les threads ou les résultats des tâches ne dépendent plus les uns des autres.

final ExecutorService executorService =
        Executors.newSingleThreadExecutor();
Future<Long> f1 = executorService.submit(new Callable<Long>() {
 
    public Long call() throws Exception {
        System.out.println("start f1");
        Thread.sleep(1000);//延时
        Future<Long> f2 =
           executorService.submit(new Callable<Long>() {
 
            public Long call() throws Exception {
                System.out.println("start f2");
                return -1L;
            }
        });
        System.out.println("result" + f2.get());
        System.out.println("end f1");
        return -1L;
    }
});
Copier après la connexion

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!

Étiquettes associées:
source:yisu.com
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal