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.
1. Saiz utas teras kumpulan benang corePoolSize
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.
2. maksimumPoolSize Bilangan maksimum utas dalam kumpulan utas
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.
3. KeepAliveTime masa kelangsungan benang terbiar
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
4. Unit masa kelangsungan benang terbiar
Unit pengukuran keepAliveTime
5. gilir kerja workQueue
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.
6. Kilang benang kilang kilang
Kilang yang digunakan semasa membuat utas baharu, boleh digunakan untuk menetapkan nama utas, sama ada benang daemon, dll.
7 . Strategi penolakan pengendali
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Panduan untuk Square Root di Java. Di sini kita membincangkan cara Square Root berfungsi di Java dengan contoh dan pelaksanaan kodnya masing-masing.

Panduan Nombor Sempurna di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor Perfect dalam Java?, contoh dengan pelaksanaan kod.

Panduan untuk Penjana Nombor Rawak di Jawa. Di sini kita membincangkan Fungsi dalam Java dengan contoh dan dua Penjana berbeza dengan contoh lain.

Panduan untuk Nombor Armstrong di Jawa. Di sini kita membincangkan pengenalan kepada nombor Armstrong di java bersama-sama dengan beberapa kod.

Panduan untuk Weka di Jawa. Di sini kita membincangkan Pengenalan, cara menggunakan weka java, jenis platform, dan kelebihan dengan contoh.

Panduan untuk Nombor Smith di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor smith di Jawa? contoh dengan pelaksanaan kod.

Dalam artikel ini, kami telah menyimpan Soalan Temuduga Spring Java yang paling banyak ditanya dengan jawapan terperinci mereka. Supaya anda boleh memecahkan temuduga.

Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah
