Rumah >Java >javaTutorial >Longgokan benang Java
Lambakan benang java ditakrifkan sebagai longgokan semua benang pemprosesan langsung dalam memori tindanan; ia boleh menjadi peranan penting dalam artifak untuk mendiagnosis penggunaan CPU seperti pancang, kebuntuan, masalah memori, aplikasi tidak bertindak balas dengan beberapa kod ralat lalai sooor permintaan dan masa tindak balas dan walaupun beberapa isu berkaitan sistem lain juga dikira dan berkaitan dengan utas dump mesej berdasarkan pelayan aplikasi ia akan dikonfigurasikan kepada fail konfigurasi pelayan terutamanya yang disyorkan untuk lebih daripada 1 dump thread dan sekurang-kurangnya 10 dump thread yang digunakan pada selang masa yang tetap dalam JVM.
Mulakan Kursus Pembangunan Perisian Percuma Anda
Pembangunan web, bahasa pengaturcaraan, ujian perisian & lain-lain
Jika kami menggunakan bahasa pengaturcaraan java, ia boleh mempunyai kelas lalai dan kaedah yang digunakan untuk mencipta aplikasi web dengan lebih canggih. Di sini pembuangan benang akan dianalisis menggunakan alatan di sini; sintaks asas untuk pembuangan benang java adalah seperti berikut.
class className { public static void main(String[] args) throws Exception { Object o = new Object(); Object o1= new Object(); Thread t=new Thread(new DeadLockRunnable(o,o1)); t.sleep(); --some java code logics--- } }
Kod di atas ialah sintaks asas untuk mencipta pembuangan benang dalam memori tindanan dengan bantuan konsep seperti kebuntuan dan lain-lain. Selain itu, kita boleh menggunakan beberapa kaedah lalai seperti DeadLockRunnable, ManagementFactory.getThreadMXBean(); ini ialah beberapa kaedah untuk mencapai pembuangan benang dalam tindanan pengaturcaraan.
Dalam aplikasi Java, kami telah menggunakan pelayan web dan pelayan aplikasi untuk menjalankan aplikasi dalam kedua-dua penyemak imbas dan desktop (jika ia berada dalam aplikasi kendiri). Disebabkan oleh pelayan web yang telah kami gunakan untuk mengakses berpuluh hingga ratusan utas untuk memproses dalam sebilangan besar pengguna serentak. Jika andaikan aplikasi akan diakses untuk lebih daripada satu pengguna, iaitu) dua atau lebih pengguna mengakses sumber yang sama pada masa yang sama, perbalahan antara kedua-dua utas tidak dapat dielakkan, malah kadangkala kebuntuan akan berlaku. Berdasarkan pelayan web, pembuangan benang akan dikonfigurasikan seperti contohnya; Apache tomcat akan mengkonfigurasi pembuangan benang menggunakan pilihan seperti
Lambakan benang mempunyai keadaan berbeza untuk menunjukkan sama ada pengguna aplikasi masih hidup atau tidak, Keep- Alive-Timer juga merupakan nama benang; ini harus digunakan untuk mencipta utas KeepAliveCache, yang telah ditetapkan untuk utas http hidup. Setiap dan setiap urutan yang dibuat dengan menggunakan JVM kerana ia telah dimulakan selepas daemon seperti benang, yang bermaksud bahawa ia tidak akan dapat menghalang JVM daripada urutan terakhir yang sedang berjalan daripada dimatikan dalam kedua-dua mesin dan aplikasi.
Beberapa keadaan utas yang paling penting seperti Runnable, Waiting/Timed_waiting dan Disekat ini adalah beberapa keadaan yang akan digunakan untuk menyekat dan menunggu utas jika aplikasi atau proses berada dalam multi-threading jadi setiap kali utas dibuat adalah automatik pergi ke antara muka Runnable selepas itu beberapa metadata berkaitan tentang keutamaan thread termasuk keutamaan thread os jika thread yang kita jalankan thread adalah keadaan penyekatan mod runnable digunakan untuk menyekat benang jika aplikasi berada dalam multi-threading selepas selesai satu benang, satu lagi benang dilakukan sehingga ia telah dikunci keadaan jadi dengan bantuan konsep seperti blok benang disegerakkan, dsb. menggunakan konsep ini dan contoh mereka ia telah dicapai. Status menunggu ialah masa menunggu benang dikira dan ia telah disimpan dalam memori benang yang dipanggil kumpulan benang yang telah ditunggu untuk berfungsi di negeri ini.
Contoh yang berbeza dinyatakan di bawah:
Kod:
package com.first; import java.net.ServerSocket; import java.net.Socket; public class Example { public void run() { System.out.println("Multithreads names are : " + Thread.currentThread().getName()); } public static void main(String[] args) throws Exception { long waitingtimethread = 2000 * 30 * 2; long startingthread = System.currentTimeMillis(); Thread t = new Thread(); t.start(); Thread.sleep(300); t.run(); try ( ServerSocket s = new ServerSocket(3000); Socket s1 = s.accept() ) { Thread t1 = new Thread(); t1.start(); while (t1.isAlive()) { if (demo(startingthread, waitingtimethread, t1)) { t1.interrupt(); t1.join(); } } } catch (Exception e) { System.err.println("The Excetion will be captured here."+e); } System.out.println("Multithreads names are : " + Thread.currentThread().getName()); System.out.println("We can check the daemon thread is used or not: " + Thread.currentThread().isDaemon()); } static boolean demo(long startingthread, long waitingtimethread, Thread t1) { return ((System.currentTimeMillis() - startingthread) > waitingtimethread) && t1.isAlive(); } }
Output:
Kod:
package com.first; import java.net.ServerSocket; import java.net.Socket; public class Example { static boolean demo(long startingthread, long waitingtimethread, Thread t1) { return ((System.currentTimeMillis() - startingthread) > waitingtimethread) && t1.isAlive(); } public static void main(String[] args) throws Exception { long waitingtimethread = 2000 * 30 * 2; long startingthread = System.currentTimeMillis(); Thread t = new Thread(); Thread t2 = new Thread(); t.start(); Thread.sleep(300); t.run(); try ( ServerSocket s = new ServerSocket(3000); Socket s1 = s.accept() ) { Thread t1 = new Thread(); t1.start(); while (t1.isAlive()) { if (demo(startingthread, waitingtimethread, t1)) { t1.interrupt(); t1.join(); t1.notifyAll(); t2.notify(); } } } catch (Exception e) { e.printStackTrace(); } System.out.println("Multithreads names are : " + Thread.currentThread().getName()); } }
Output:
Kod:
package com.first; public class Example extends Thread { public void run() { System.out.println("Multithreads names are : " + Thread.currentThread().getName()); System.out.println("We can check the daemon thread is used or not: " + Thread.currentThread().isDaemon()); } public static void main(String[] args) { Example e1 = new Example(); Example e2 = new Example(); e1.start(); e1.setDaemon(true); e2.start(); } }
Output:
Dalam tiga contoh di atas, kami menggunakan senario berbeza untuk konsep pembuangan benang; juga, kami menggunakan pelbagai jenis kaedah benang terbina dalam seperti notify(), Timed_Waiting(), sleep(); kaedah statik serentak ini akan mencapai pembuangan berbilang benang dalam java.
Secara amnya, pembuangan benang ialah beberapa mekanisme yang berguna untuk aplikasi web berasaskan java untuk mendapatkan laporan yang dianalisis secara terperinci. Ia termasuk berbilang pengguna yang mengakses aplikasi secara langsung atau tidak langsung; proses ini akan membantu untuk menyelesaikan gangguan dan meningkatkan prestasi aplikasi.
Atas ialah kandungan terperinci Longgokan benang Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!