Rumah >Java >javaTutorial >Bagaimana untuk melaksanakan kolam benang berskala dalam pengaturcaraan serentak Java?
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.
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
方法返回一个可扩展的线程池,它根据需要创建和销毁线程。如果队列中没有正在运行的任务,线程将被销毁,而当新的任务提交时,新的线程将被创建。
可扩展线程池可以通过设置以下属性進行配置:
可以使用ThreadPoolExecutor
类setCorePoolSize(int corePoolSize)
、setMaximunPoolSize(int maximumPoolSize)
、setKeepAliveTime(long keepAliveTime, TimeUnit unit)
和setThreadFactory(ThreadFactory threadFactory)
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: 🎜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!