Dans un scénario où plusieurs files d'attente contiennent des tâches à exécuter séquentiellement par un service exécuteur, les opérations de blocage peuvent consommer un espace de pile excessif. Pour atténuer ce problème, une approche non bloquante est souhaitée.
Une solution consiste à définir une interface de rappel avec des méthodes pour traiter les résultats et transmettre les paramètres nécessaires. Cette interface peut être implémentée dans une classe wrapper pour les tâches Runnable, qui sont ensuite soumises au service exécuteur. Une fois la tâche terminée, l'interface de rappel est invoquée.
interface Callback { void complete(); } class CallbackTask implements Runnable { private final Runnable task; private final Callback callback; CallbackTask(Runnable task, Callback callback) { this.task = task; this.callback = callback; } public void run() { task.run(); callback.complete(); } }
Alternativement, Java 8 introduit CompletableFuture, qui fournit des mécanismes de composition de tâches asynchrones et de traitement conditionnel. Voici un exemple utilisant CompletableFuture :
CompletableFuture<String> f = CompletableFuture.supplyAsync(() -> ExampleService.work()); f.thenAccept(listener::notify);
Dans cet exemple, SampleService.work() est la tâche à exécuter de manière asynchrone. La méthode notify est le rappel qui sera invoqué lorsque la tâche est terminée.
Grâce à ces techniques, les tâches peuvent être soumises à un service exécuteur sans blocage, permettant un traitement efficace des grandes files d'attente tout en évitant l'épuisement de l'espace de pile.
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!