Maison> Java> javaDidacticiel> le corps du texte

Comment utiliser le framework Fork/Join pour la programmation parallèle en programmation simultanée Java ?

WBOY
Libérer: 2024-05-08 15:57:02
original
241 Les gens l'ont consulté

Comment utiliser le framework Java Fork/Join pour la programmation parallèle ? Créez une classe de tâches et implémentez l'interface RecursiveAction ou RecursiveTask. Créez un pool Fork/Join et gérez l’exécution des tâches. Appelez la méthode fork() pour soumettre la tâche au pool et la décomposer en sous-tâches. Appelez la méthode join() pour attendre la fin de la tâche et obtenir les résultats (pour RecursiveTask).

Java 并发编程中如何使用 Fork/Join 框架进行并行编程?

Programmation simultanée Java : programmation parallèle à l'aide du framework Fork/Join

Le framework Fork/Join est une bibliothèque Java qui fournit un cadre léger pour exécuter efficacement des tâches parallèles. Il est basé sur un algorithme de vol de travail qui permet aux threads de collaborer sur des tâches, maximisant ainsi l'utilisation des ressources CPU.

Comment utiliser le framework Fork/Join :

  1. Créez une classe de tâches :Cette classe doit implémenterjava.util.concurrent.RecursiveActionoujava.util. interface concurrent.RecursiveTask. RecursiveAction est utilisé pour effectuer des tâches qui ne renvoient pas de valeur, contrairement à RecursiveTask.java.util.concurrent.RecursiveActionjava.util.concurrent.RecursiveTask接口。RecursiveAction 用于执行不返回值的任务,而 RecursiveTask 则会返回值。
  2. 创建一个 Fork/Join 池:使用java.util.concurrent.ForkJoinPool创建一个线程池。它将管理 Fork/Join 任务的执行。
  3. Fork 任务:调用fork()方法将任务提交给 Fork/Join 池。池会将任务分解成更小的子任务,并分配给可用的线程。
  4. Join 任务:调用join()
Créez un pool Fork/Join :

Utilisezjava.util.concurrent.ForkJoinPoolpour créer un pool de threads. Il gérera l’exécution des tâches Fork/Join.

Tâche Fork :

Appelez la méthodefork()pour soumettre la tâche au pool Fork/Join. Le pool divise les tâches en sous-tâches plus petites et les affecte aux threads disponibles.

Join task : Appelez la méthode join()et attendez que la tâche se termine. Pour RecursiveTask, il renvoie également la valeur de retour au thread principal. Exemple pratique : Supposons que nous ayons une tâche parallèle qui calcule la somme de tous les nombres impairs dans une liste de nombres. Nous pouvons implémenter cela en utilisant le framework Fork/Join comme suit :
import java.util.concurrent.ForkJoinPool; import java.util.concurrent.RecursiveAction; public class OddSumTask extends RecursiveAction { private int[] numbers; private int start; private int end; public OddSumTask(int[] numbers, int start, int end) { this.numbers = numbers; this.start = start; this.end = end; } @Override protected void compute() { int sum = 0; for (int i = start; i < end; i++) { if (numbers[i] % 2 != 0) { sum += numbers[i]; } } System.out.println("Partial sum: " + sum); } } public class Main { public static void main(String[] args) { // 创建一个数字列表 int[] numbers = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; // 创建一个 Fork/Join 池 ForkJoinPool pool = new ForkJoinPool(); // 创建一个 OddSumTask OddSumTask task = new OddSumTask(numbers, 0, numbers.length); // Fork 任务 pool.invoke(task); } }
Copier après la connexion
L'exécution de ce code ajoutera les nombres impairs dans la liste et imprimera la somme locale calculée par chaque thread.

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:php.cn
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
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!