Kelas ThreadPoolExecutor
java.util.concurrent.ThreadPoolExecutor adalah ExecutorService untuk menjalankan setiap tugas yang dikirimkan menggunakan salah satu dari beberapa kumpulan thread, biasanya dikonfigurasi menggunakan metode pabrik Executors. Ini juga menyediakan berbagai metode utilitas untuk memeriksa statistik utas saat ini dan mengontrolnya.
Metode ThreadPoolExecutor
Sr.No. | Metode & Deskripsi |
---|---|
1 | protected void afterExecute(Runnable r, Throwable t) Metode dipanggil setelah menyelesaikan eksekusi Runnable yang diberikan. |
2 | void allowCoreThreadTimeOut(boolean value) Menyetel kebijakan yang mengatur apakah utas inti dapat waktunya habis dan dihentikan jika tidak ada tugas yang tiba dalam waktu keep-hidup, diganti jika diperlukan ketika tugas baru tiba. |
3 | boolean allowsCoreThreadTimeOut() Mengembalikan nilai true jika kumpulan ini memungkinkan utas inti untuk waktu habis dan berakhir jika tidak ada tugas yang tiba dalam waktu keepAlive, diganti jika diperlukan ketika tugas baru tiba. |
4 | boolean awaitTermination(long timeout, TimeUnit unit) Memblokir hingga semua tugas telah menyelesaikan eksekusi setelah permintaan penghentian, atau terjadi waktu tunggu, atau utas saat ini terputus, mana saja yang terjadi lebih dulu. |
5 | protected void beforeExecute(Thread t, Runnable r) Metode dipanggil sebelum menjalankan Runnable yang diberikan di thread yang diberikan. |
6 | void execute(Runnable command) Menjalankan tugas yang diberikan suatu saat nanti. |
7 | protected void finalize() Memanggil shutdown ketika pelaksana ini tidak lagi direferensikan dan tidak memiliki utas. |
8 | int getActiveCount() Mengembalikan perkiraan jumlah utas yang secara aktif menjalankan tugas. |
9 | long getCompletedTaskCount() Mengembalikan perkiraan jumlah tugas yang telah menyelesaikan eksekusi. |
10 | int getCorePoolSize() Mengembalikan jumlah inti utas. |
11 | long getKeepAliveTime(TimeUnit unit) Mengembalikan waktu tetap hidup utas, yang merupakan jumlah waktu utas yang melebihi ukuran kumpulan inti dapat tetap menganggur sebelum dihentikan. |
12 | int getLargestPoolSize() Menampilkan jumlah untaian terbesar yang pernah ada di kumpulan secara bersamaan. |
13 | int getMaximumPoolSize() Menampilkan jumlah utas maksimum yang diizinkan. |
14 | int getPoolSize() Mengembalikan jumlah utas saat ini di pangkalan. |
15 | BlockingQueue
Mengembalikan antrian tugas yang digunakan oleh pelaksana ini. |
15 | RejectedExecutionHandler getRejectedExecutionHandler() Mengembalikan penangan saat ini untuk tugas yang tidak bisa dijalankan. |
16 | long getTaskCount() Mengembalikan perkiraan jumlah tugas yang pernah dijadwalkan untuk dieksekusi. |
17 | ThreadFactory getThreadFactory() Mengembalikan pabrik utas yang digunakan untuk membuat utas baru. |
18 | boolean isShutdown() Mengembalikan nilai true jika pelaksana ini telah ditutup. |
19 | boolean isTerminated() Mengembalikan nilai benar jika semua tugas telah diselesaikan setelah dimatikan. |
20 | boolean isTerminating() Mengembalikan nilai true jika pelaksana ini sedang dalam proses penghentian setelah shutdown () atau shutdownNow () tetapi belum sepenuhnya dihentikan. |
21 | int prestartAllCoreThreads() Memulai semua utas inti, menyebabkan utas menunggu pekerjaan. |
22 | boolean prestartCoreThread() Memulai utas inti, menyebabkannya menunggu pekerjaan dengan santai. |
23 | void purge() Mencoba menghapus semua tugas Masa Depan yang telah dibatalkan dari antrian pekerjaan. |
24 | boolean remove(Runnable task) Menghapus tugas ini dari antrian internal pelaksana jika ada, sehingga menyebabkannya tidak dijalankan jika belum dimulai. |
25 | void setCorePoolSize(int corePoolSize) Menetapkan jumlah inti utas. |
26 | void setKeepAliveTime(long time, TimeUnit unit) Menyetel batas waktu utas mungkin tetap menganggur sebelum dihentikan. |
27 | void setMaximumPoolSize(int maximumPoolSize) Menetapkan jumlah utas maksimum yang diizinkan. |
28 | void setRejectedExecutionHandler(RejectedExecutionHandler handler) Menyetel penangan baru untuk tugas yang tidak bisa dijalankan. |
29 | void setThreadFactory(ThreadFactory threadFactory) Mengatur pabrik utas yang digunakan untuk membuat utas baru. |
30 | void shutdown() Memulai penghentian secara tertib di mana tugas yang dikirimkan sebelumnya dijalankan, tetapi tidak ada tugas baru yang akan diterima. |
31 | List<Runnable> shutdownNow() Mencoba menghentikan semua tugas yang sedang dijalankan secara aktif, menghentikan pemrosesan tugas menunggu, dan mengembalikan daftar tugas yang sedang menunggu eksekusi. |
32 | protected void terminated() Metode dipanggil ketika Pelaksana telah dihentikan. |
33 | String toString() Mengembalikan string yang mengidentifikasi kumpulan ini, serta statusnya, termasuk indikasi status berjalan dan perkiraan jumlah pekerja dan tugas. |
Contoh
Program TestThread berikut menunjukkan penggunaan antarmuka ThreadPoolExecutor di lingkungan berbasis thread.
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class TestThread {
public static void main(final String[] arguments) throws InterruptedException {
ThreadPoolExecutor executor = (ThreadPoolExecutor)Executors.newCachedThreadPool();
//Stats before tasks execution
System.out.println("Largest executions: "
+ executor.getLargestPoolSize());
System.out.println("Maximum allowed threads: "
+ executor.getMaximumPoolSize());
System.out.println("Current threads in pool: "
+ executor.getPoolSize());
System.out.println("Currently executing threads: "
+ executor.getActiveCount());
System.out.println("Total number of threads(ever scheduled): "
+ executor.getTaskCount());
executor.submit(new Task());
executor.submit(new Task());
//Stats after tasks execution
System.out.println("Core threads: " + executor.getCorePoolSize());
System.out.println("Largest executions: "
+ executor.getLargestPoolSize());
System.out.println("Maximum allowed threads: "
+ executor.getMaximumPoolSize());
System.out.println("Current threads in pool: "
+ executor.getPoolSize());
System.out.println("Currently executing threads: "
+ executor.getActiveCount());
System.out.println("Total number of threads(ever scheduled): "
+ executor.getTaskCount());
executor.shutdown();
}
static class Task implements Runnable {
public void run() {
try {
Long duration = (long) (Math.random() * 5);
System.out.println("Running Task! Thread Name: " +
Thread.currentThread().getName());
TimeUnit.SECONDS.sleep(duration);
System.out.println("Task Completed! Thread Name: " +
Thread.currentThread().getName());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
Ini akan menghasilkan hasil sebagai berikut.
Keluaran
Largest executions: 0
Maximum allowed threads: 2147483647
Current threads in pool: 0
Currently executing threads: 0
Total number of threads(ever scheduled): 0
Core threads: 0
Largest executions: 2
Maximum allowed threads: 2147483647
Current threads in pool: 2
Currently executing threads: 2
Total number of threads(ever scheduled): 2
Running Task! Thread Name: pool-1-thread-2
Running Task! Thread Name: pool-1-thread-1
Task Completed! Thread Name: pool-1-thread-1
Task Completed! Thread Name: pool-1-thread-2