Comment implémenter le multi-threading Java : 1. Implémenter l'interface Runnable ; 2. Hériter de la classe Thread ; 3. Utiliser le framework Executor ; 4. Utiliser CompletableFuture ; Introduction détaillée : 1. Implémentez l'interface Runnable. L'interface Runnable en Java n'a qu'une seule méthode run() En implémentant cette interface et en réécrivant la méthode run(), vous pouvez écrire du code d'exécution multithread dans cette méthode, démarrer un thread. , etc. attendez.
Le système d'exploitation de ce tutoriel : système Windows 10, ordinateur DELL G3.
Le multithreading Java peut être implémenté des manières suivantes :
1. Implémentez l'interface Runnable :L'interface Runnable en Java n'a qu'une seule méthode run(). En implémentant cette interface et en réécrivant la méthode run(), vous pouvez écrire du code pour une exécution multithread dans la méthode. Pour démarrer un thread, vous devez créer un objet qui implémente l'interface Runnable, le transmettre au constructeur de la classe Thread, puis appeler la méthode start() pour démarrer le thread.
public class MyRunnable implements Runnable { public void run() { // 线程执行的代码 } } Thread thread = new Thread(new MyRunnable()); thread.start();
2. Hériter de la classe Thread :La classe Thread en Java elle-même est également une classe qui implémente l'interface Runnable. Le multithreading peut être obtenu en héritant de la classe Thread et en remplaçant sa méthode run(). De même, vous devez créer un objet Thread et appeler la méthode start() pour démarrer le thread.
public class MyThread extends Thread { public void run() { // 线程执行的代码 } } MyThread thread = new MyThread(); thread.start();
3. Utilisez le framework Executor :Le framework Executor en Java fournit une méthode de programmation multithread plus flexible qui peut créer et gérer plusieurs threads. En implémentant l'interface Executor ou en utilisant la classe ExecutorService, vous pouvez créer et gérer des pools de threads plus facilement. Le framework Executor fournit également de nombreuses autres fonctions, telles que la planification des tâches, la gestion du pool de threads, etc.
ExecutorService executor = Executors.newFixedThreadPool(10); // 创建一个包含10个线程的线程池 executor.execute(new MyRunnable()); // 提交任务给线程池执行 executor.shutdown(); // 关闭线程池
4. Utilisez CompletableFuture :Java 8 introduit la classe CompletableFuture, qui fournit une méthode de programmation asynchrone plus moderne. CompletableFuture facilite l'écriture de code asynchrone et obtient les résultats en cas de besoin. Il prend également en charge des fonctionnalités avancées telles que la programmation en chaîne et la gestion des exceptions.
CompletableFuturefuture = CompletableFuture.supplyAsync(() -> { // 异步执行的代码 return "result"; }); future.thenAccept(result -> { // 处理异步执行的结果 System.out.println(result); });
5. Utilisez le framework ForkJoin :Le framework ForkJoin en Java fournit un mécanisme de calcul parallèle basé sur un algorithme de vol de travail, qui convient pour diviser les tâches en plusieurs sous-tâches. Grâce au framework ForkJoin, les tâches peuvent être divisées en plusieurs sous-threads pour être exécutées et fusionnées une fois terminées. Le framework ForkJoin convient à des scénarios tels que le traitement d'ensembles de données à grande échelle ou l'exécution de calculs complexes.
Ci-dessus sont plusieurs façons courantes d'implémenter le multithreading en Java. Chaque méthode a ses scénarios applicables, ses avantages et ses inconvénients. Dans les applications pratiques, la méthode appropriée pour implémenter le multithreading doit être sélectionnée en fonction des besoins spécifiques.
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!