Rumah >Java >javaTutorial >Apakah maksud parameter kolam benang Java
Teknologi kumpulan benang sering digunakan dalam pembangunan berbilang benang Java. Artikel ini ialah penjelasan terperinci tentang tujuh parameter semasa membuat kumpulan benang Java.
Seperti yang dapat dilihat daripada kod sumber, pembina kumpulan benang mempunyai 7 parameter
7 parameter ini ialah:
corePoolSize: Bilangan utas teras.
maximumPoolSize: Bilangan maksimum utas.
keepAliveTime: masa kelangsungan benang terbiar.
Unit Masa: unit masa.
BlockingQueue: Baris gilir tugas kumpulan benang.
ThreadFactory: Kilang untuk mencipta benang.
RejectedExecutionHandler: Strategi penolakan.
7 parameter ini akan diterangkan satu persatu di bawah.
Kumpulan benang akan mengekalkan bilangan utas minimum Walaupun jika utas ini mengendalikan status terbiar, ia tidak akan dimusnahkan melainkan membenarkanCoreThreadTimeOut ditetapkan. Bilangan minimum utas di sini ialah corePoolSize.
Selepas tugasan diserahkan kepada kumpulan utas, ia akan terlebih dahulu mengetahui sama ada terdapat utas terbiar yang masih ada. tugasan akan terus diserahkan kepada utas terbiar, jika tidak, ia akan dicache dalam baris gilir kerja (akan diperkenalkan kemudian). akan dikeluarkan dari kepala barisan kerja dan diserahkan kepada benang baru untuk diproses. Kumpulan utas tidak akan mencipta utas baharu tanpa had Ia akan mempunyai had pada bilangan maksimum utas, yang ditentukan oleh maksimumPoolSize.
Jika benang melahu dan bilangan utas semasa lebih besar daripada corePoolSize, maka selepas masa yang ditentukan, benang terbiar akan dimusnahkan, seperti yang dinyatakan di sini Masa ditetapkan oleh keepAliveTime
Unit pengukuran keepAliveTime
Baharu tugasan ialah Selepas penyerahan, ia akan mula-mula memasuki baris gilir kerja, dan kemudian tugas itu akan dikeluarkan daripada baris gilir semasa penjadualan tugas. Empat baris gilir kerja disediakan dalam jdk:
①ArrayBlockingQueue
Baris gilir sekatan bersempadan berasaskan tatasusunan, diisih mengikut FIFO. Selepas tugas baharu masuk, ia akan diletakkan di penghujung baris gilir. Apabila bilangan utas dalam kumpulan benang mencapai corePoolSize dan tugasan baharu masuk, tugasan akan diletakkan di penghujung baris gilir, menunggu untuk dijadualkan. Jika baris gilir sudah penuh, urutan baharu dibuat Jika bilangan utas telah mencapai maxPoolSize, dasar penolakan akan dilaksanakan.
②LinkedBlockingQuene
Baris gilir sekatan tanpa sempadan berdasarkan senarai terpaut (sebenarnya kapasiti maksimum ialah Interger.MAX), diisih mengikut FIFO. Disebabkan oleh sifat baris gilir yang tidak terhad, apabila bilangan utas dalam kumpulan utas mencapai corePoolSize, tugasan baharu akan disimpan dalam baris gilir tanpa membuat utas baharu sehingga maxPoolSize Oleh itu, apabila menggunakan baris gilir kerja ini, parameter maxPoolSize Sebenarnya ia tidak berfungsi.
③SynchronousQuene
Baris gilir menyekat yang tidak menyimpan cache tugasan dan mesti menunggu sehingga pengguna mengeluarkan tugas itu. Maksudnya, apabila tugasan baharu masuk, ia tidak akan dicache, tetapi akan dijadualkan secara langsung untuk melaksanakan tugasan Jika tiada utas yang tersedia, utas baharu akan dibuat Jika bilangan utas mencapai maxPoolSize. dasar penolakan akan dilaksanakan.
④PriorityBlockingQueue
Baris gilir sekatan tanpa had dengan keutamaan, keutamaan dilaksanakan melalui parameter Comparator.
Kilang yang digunakan semasa membuat utas baharu, boleh digunakan untuk menetapkan nama utas, sama ada benang daemon, dll.
Apabila tugasan dalam baris gilir kerja telah mencapai had maksimum, dan bilangan utas dalam kumpulan benang juga telah mencapai had maksimum, apakah yang perlu dilakukan jika tugasan baharu diserahkan? Dasar penolakan di sini adalah untuk menyelesaikan masalah ini. JDK menyediakan 4 dasar penolakan:
①CallerRunsPolicy
Di bawah dasar ini, kaedah jalankan tugas yang ditolak dilaksanakan secara langsung dalam urutan pemanggil , melainkan kolam benang telah ditutup, tugas akan ditinggalkan terus.
②AbortPolicy
Di bawah dasar ini, tugasan dibuang terus dan RejectedExecutionException dibuang.
③DiscardPolicy
Di bawah dasar ini, tugasan dibuang terus dan tiada apa yang dilakukan.
④DiscardOldestPolicy
Di bawah dasar ini, buang tugas terawal yang memasuki baris gilir, kemudian cuba letakkan tugas yang ditolak ke dalam baris gilir
Atas ialah kandungan terperinci Apakah maksud parameter kolam benang Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!