cari
RumahJavajavaTutorialPenggunaan ExecutorService dan FutureTask dalam pengaturcaraan selari Java

Gunakan ExecutorService untuk mengurus kumpulan benang dan melaksanakan tugas, dan gunakan FutureTask untuk melaksanakan tugasan secara tidak segerak dan mendapatkan semula keputusannya. ExecutorService menyediakan kaedah seperti execute() dan submit(), dan FutureTask menyediakan kaedah get(), isDone(), dan cancel(). Contoh praktikal menunjukkan cara menggunakannya untuk mengira nombor dalam jujukan Fibonacci secara selari.

Penggunaan ExecutorService dan FutureTask dalam pengaturcaraan selari Java

Penggunaan ExecutorService dan FutureTask dalam Java Parallel Programming

Pengenalan

ExecutorService dan FutureTask adalah alatan berguna untuk pengaturcaraan selari. ExecutorService membolehkan anda mengurus satu set utas, manakala FutureTask membenarkan anda melaksanakan tugas secara tak segerak dan mendapatkan semula keputusannya.

ExecutorService

ExecutorService ialah antara muka yang mewakili koleksi tugas urutan boleh laku. Anda boleh membuat pelaksanaan berbeza ExecutorService menggunakan:

ExecutorService executorService = Executors.newFixedThreadPool(5);

di mana 5 mewakili bilangan utas dalam kumpulan benang.

ExecutorService menyediakan kaedah berikut untuk melaksanakan tugas:

  • execute(Runnable task): Jalankan tugas Runnable. execute(Runnable task):执行一个 Runnable 任务。
  • submit(Runnable task):执行一个 Runnable 任务并返回值。
  • submit(Callable<t> task)</t>:执行一个 Callable 任务并返回值。

FutureTask

FutureTask 是一个 Callable 任务的包装器,它允许您异步执行任务并稍后检索其结果。您可以使用以下方法创建 FutureTask:

FutureTask<String> futureTask = new FutureTask<>(() -> "Hello, world!");

其中,() -> "Hello, world!" 是要执行的 Callable 任务。

FutureTask 提供以下方法来检索任务结果:

  • get():阻塞等待任务完成并返回结果。
  • isDone():检查任务是否已完成。
  • cancel(boolean mayInterruptIfRunning)
  • serahkan(Tugas boleh dijalankan): Laksanakan tugasan Boleh Jalan dan kembalikan nilai.

serahkan(Tugas Boleh Panggil): Laksanakan tugasan Boleh Panggil dan kembalikan nilai.

FutureTask

FutureTask ialah pembalut tugas Boleh Panggil yang membolehkan anda melaksanakan tugasan secara tidak segerak dan mendapatkan semula keputusannya kemudian. Anda boleh mencipta FutureTask menggunakan kaedah berikut: 🎜
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.FutureTask;

class FibonacciTask implements Callable<Long> {

    private int n;

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

    @Override
    public Long call() {
        long a = 0;
        long b = 1;
        for (int i = 0; i < n; i++) {
            long temp = a;
            a = b;
            b = temp + b;
        }
        return a;
    }
}

public class Main {

    public static void main(String[] args) {
        ExecutorService executorService = Executors.newFixedThreadPool(4);
        FutureTask<Long>[] tasks = new FutureTask[10];

        // 创建并提交任务
        for (int i = 0; i < 10; i++) {
            tasks[i] = new FutureTask<>(new FibonacciTask(i));
            executorService.submit(tasks[i]);
        }

        // 获取并打印结果
        for (int i = 0; i < 10; i++) {
            try {
                System.out.println("斐波那契数列第 " + i + " 项:" + tasks[i].get());
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

        // 关闭 ExecutorService
        executorService.shutdown();
    }
}
🎜di mana () -> "Hello, world!" ialah tugasan Boleh Panggil untuk dilaksanakan. 🎜🎜FutureTask menyediakan kaedah berikut untuk mendapatkan semula hasil tugasan: 🎜🎜🎜get(): blok menunggu tugasan selesai dan mengembalikan hasilnya. 🎜🎜isDone(): Semak sama ada tugasan telah selesai. 🎜🎜batal(boolean mayInterruptIfRunning): Batalkan tugasan (jika boleh). 🎜🎜🎜🎜Kes Praktikal🎜🎜🎜Pertimbangkan program yang mengira jujukan Fibonacci. Kami boleh menggunakan ExecutorService dan FutureTask untuk mengira berbilang nombor Fibonacci secara selari: 🎜rrreee🎜 Dalam contoh ini, kami mencipta ExecutorService dan menyerahkan 10 tugasan FibonacciTask. Setiap tugas mengira nombor dalam jujukan Fibonacci. Menggunakan FutureTask, kami dapat melaksanakan tugas ini secara tidak segerak dan mendapatkan keputusannya kemudian. 🎜

Atas ialah kandungan terperinci Penggunaan ExecutorService dan FutureTask dalam pengaturcaraan selari Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa