Rumah >Java >javaTutorial >Bagaimana untuk melaksanakan kolam benang berskala dalam pengaturcaraan serentak Java?

Bagaimana untuk melaksanakan kolam benang berskala dalam pengaturcaraan serentak Java?

王林
王林asal
2024-05-04 08:21:01845semak imbas

Kolam benang berskala di Java boleh melaraskan bilangan utas mengikut permintaan secara dinamik dan dicipta menggunakan kaedah newCachedThreadPool dalam kelas Executors. Sifat boleh dikonfigurasikan termasuk bilangan utas teras, bilangan maksimum utas, masa pengekalan benang melahu dan kilang benang, yang boleh ditetapkan melalui kaedah yang sepadan. Dalam kes sebenar, kumpulan benang berskala digunakan untuk menyerahkan senarai tugasan dan menunggu tugasan selesai.

Bagaimana untuk melaksanakan kolam benang berskala dalam pengaturcaraan serentak Java?

Pelaksanaan kumpulan benang berskala dalam pengaturcaraan serentak Java

Dalam pengaturcaraan serentak Java, kumpulan benang ialah alat biasa untuk mengurus benang. Kumpulan benang yang direka bentuk dengan baik boleh meningkatkan prestasi, kebolehskalaan dan ketersediaan. Artikel ini akan memperkenalkan cara menggunakan kelas Executors dalam Java untuk mencipta dan mengkonfigurasi kumpulan benang berskala dan menyediakan kes praktikal. Executors类创建和配置一个可扩展的线程池,并提供一个实战案例。

创建可扩展线程池

可扩展线程池的關鍵是要根据需求动态调整线程池中的线程数量。Java中的Executors类提供了创建可扩展线程池的方法:

ExecutorService executor = Executors.newCachedThreadPool();

newCachedThreadPool方法返回一个可扩展的线程池,它根据需要创建和销毁线程。如果队列中没有正在运行的任务,线程将被销毁,而当新的任务提交时,新的线程将被创建。

配置线程池

可扩展线程池可以通过设置以下属性進行配置:

  • corePoolSize:最小线程数,无论系统负载如何,始终保持活动状态。
  • maximumPoolSize:最大线程数,仅在队列已满时创建。
  • keepAliveTime:多余线程保持活动的时间,单位为毫秒。
  • threadFactory:用于创建新线程的工厂。

可以使用ThreadPoolExecutorsetCorePoolSize(int corePoolSize)setMaximunPoolSize(int maximumPoolSize)setKeepAliveTime(long keepAliveTime, TimeUnit unit)setThreadFactory(ThreadFactory threadFactory)

Buat kumpulan benang berskala

Kunci kepada kumpulan benang boleh skala ialah dengan melaraskan bilangan benang dalam kumpulan benang secara dinamik berdasarkan permintaan. Kelas Executors dalam Java menyediakan kaedah untuk mencipta kumpulan benang boleh diperluaskan:

import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class Example {

    public static void main(String[] args) {
        ExecutorService executor = Executors.newCachedThreadPool();

        List<Callable<Integer>> tasks = List.of(
            () -> { return 1; },
            () -> { return 2; },
            () -> { return 3; }
        );

        List<Future<Integer>> results = executor.invokeAll(tasks);

        for (Future<Integer> result : results) {
            System.out.println(result.get());
        }

        executor.shutdown();
    }
}

Kaedah newCachedThreadPool mengembalikan kumpulan benang boleh dilanjutkan yang mencipta dan memusnahkan benang mengikut keperluan. Jika tiada tugas berjalan dalam baris gilir, utas akan dimusnahkan dan apabila tugas baharu diserahkan, utas baharu akan dibuat.

Mengkonfigurasi kumpulan benang 🎜🎜Kolam benang berskala boleh dikonfigurasikan dengan menetapkan sifat berikut: 🎜
  • corePoolSize: Bilangan minimum utas untuk sentiasa kekal aktif tanpa mengira beban sistem .
  • maximumPoolSize: Bilangan maksimum urutan, dibuat hanya apabila baris gilir penuh.
  • keepAliveTime: Masa yang lebihan benang kekal aktif, dalam milisaat.
  • threadFactory: Factory digunakan untuk membuat thread baharu.
🎜Anda boleh menggunakan kelas ThreadPoolExecutor setCorePoolSize(int corePoolSize), setMaximunPoolSize(int maximumPoolSize), kaedah setKeepAliveTime (keepAliveTime panjang, unit TimeUnit) dan setThreadFactory(ThreadFactory threadFactory) menetapkan sifat ini. 🎜🎜Kes praktikal🎜🎜Berikut ialah kes praktikal menggunakan kumpulan benang berskala: 🎜rrreee🎜Dalam contoh ini, kami mencipta kumpulan benang berskala di mana bilangan benang dilaraskan mengikut bilangan tugasan yang diserahkan. Ia menyerahkan senarai tugasan dan menunggu semua tugasan selesai. Akhirnya, ia menutup kumpulan benang. 🎜

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan kolam benang berskala dalam pengaturcaraan serentak 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