FutureTask and Callable: Perbezaan dalam Java concurrency
Dalam pengaturcaraan serentak Java, FutureTask
dan Cllable
memainkan peranan penting, dan perbezaan antara mereka perbezaannya ialah: FutureTask
和 Callable
扮演着重要的角色,它们之间的区别在于:
Callable
Runnable
,但具有返回值。call()
方法,返回任务的结果。FutureTask
Future
接口,表示正在执行或已完成的异步任务。Callable
对象,用于管理任务执行的细节。get()
)并检查任务是否完成(isDone()
)。区别
特征 | Callable | FutureTask |
---|---|---|
返回值 | 无返回值 | 返回任务结果 |
多结果支持 | 不支持 | 支持多个 FutureTask 代表同一 Callable
|
取消任务 | 不支持 | 支持通过调用 cancel() 取消任务 |
异常处理 |
call() 方法中处理 |
FutureTask 提供 get() 方法来处理异常 |
实战案例
假设我们有一个简单任务,计算斐波那契数列的第一个 n 个元素。
Callable 实现:
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 实现:
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 + " "); } } }
在此示例中,我们使用 Callable
来定义任务,使用 FutureTask
来管理任务执行。通过调用 get()
Dapat dijalankan
, tetapi dengan nilai pulangan. call()
ditakrifkan untuk mengembalikan hasil tugasan. Masa Depan
untuk mewakili tugas tak segerak yang sedang dilaksanakan atau diselesaikan. Boleh Panggil
untuk mengurus butiran pelaksanaan tugas. get()
) dan semak sama ada tugasan selesai (isDone()
). Ciri | Boleh Dipanggil | FutureTask |
---|---|---|
Nilai pulangan | Tiada nilai pulangan | Kembalikan hasil tugasan |
Banyak Sokongan keputusan | Tidak disokong | Sokong berbilang FutureTask yang mewakili Boleh Dipanggil
|
Pembatalan tugas | Tidak disokong | Menyokong pembatalan tugas dengan memanggil batal()
|
panggilan() dikendalikan dalam kaedah |
FutureTask dan get() disediakan untuk Mengendalikan pengecualian
|
Cllable
untuk mentakrifkan tugas dan FutureTask
untuk mengurus tugasan . Dengan memanggil kaedah get()
, kita boleh mendapatkan jujukan Fibonacci selepas tugasan selesai. 🎜Atas ialah kandungan terperinci Apakah perbezaan antara FutureTask dan Callable dalam fungsi Java concurrency dan multi-threading?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!