Home  >  Article  >  Java  >  What is the difference between FutureTask and Callable in Java function concurrency and multi-threading?

What is the difference between FutureTask and Callable in Java function concurrency and multi-threading?

WBOY
WBOYOriginal
2024-04-27 10:45:01470browse

What is the difference between FutureTask and Callable in Java function concurrency and multi-threading?

FutureTask and Callable: Difference in Java Concurrency

In Java concurrent programming, FutureTask and Callable plays an important role, and the difference between them is:

Callable

  • represents a task that can be executed concurrently.
  • Similar to Runnable, but with a return value.
  • defines a call() method to return the result of the task.

FutureTask

  • Implements the Future interface, representing an asynchronous task that is being executed or completed.
  • Wraps a Callable object to manage the details of task execution.
  • Provides methods to get the task results (get()) and check whether the task is completed (isDone()).

Difference

##Cancel taskNot supportedSupports canceling the task by calling Exception handling
Features Callable FutureTask
Return value No return value Return task results
Multiple results supported Not supported Support multiple FutureTask Represents the same Callable
cancel()
call() Processing in the method FutureTask Provides the get() method to handle exceptions

Practical Case

Suppose we have a simple task to calculate the first n elements of the Fibonacci sequence.

Callable implementation:

import java.util.concurrent.Callable;

public class FibonacciCallable implements Callable<Integer[]> {

    private int n;

    public FibonacciCallable(int n) {
        this.n = n;
    }

    @Override
    public Integer[] call() {
        Integer[] fibSequence = new Integer[n];
        fibSequence[0] = 0;
        fibSequence[1] = 1;
        for (int i = 2; i < n; i++) {
            fibSequence[i] = fibSequence[i - 1] + fibSequence[i - 2];
        }
        return fibSequence;
    }
}

FutureTask implementation:

import java.util.concurrent.FutureTask;
import java.util.concurrent.ExecutionException;

public class FibonacciFutureTask {

    public static void main(String[] args) {
        int n = 10;
        FibonacciCallable callable = new FibonacciCallable(n);
        FutureTask<Integer[]> futureTask = new FutureTask<>(callable);
        new Thread(futureTask).start();

        Integer[] fibSequence;
        try {
            fibSequence = futureTask.get();  // 等待任务完成并获取结果
        } catch (InterruptedException | ExecutionException e) {
            e.printStackTrace();
        }

        System.out.println("Fibonacci sequence upto " + n + " elements:");
        for (Integer fib : fibSequence) {
            System.out.print(fib + " ");
        }
    }
}

In this example, we use

Callable to define tasks and use FutureTask to manage task execution. By calling the get() method, we can get the Fibonacci sequence after the task is completed.

The above is the detailed content of What is the difference between FutureTask and Callable in Java function concurrency and multi-threading?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn