cari
RumahJavajavaTutorialApabila Tomcat memuat modul Spring-Web, adakah mekanisme SPI benar-benar memusnahkan prinsip penglihatan Java Class Loaders?

Apabila Tomcat memuat modul Spring-Web, adakah mekanisme SPI benar-benar memusnahkan prinsip penglihatan Java Class Loaders?

Tomcat dan Spring-Web Module Loading: Analisis tingkah laku pemuatan kelas di bawah mekanisme SPI

Apabila Tomcat memuat modul Spring-Web, ia menggunakan mekanisme Java SPI (Interface Penyedia Perkhidmatan) untuk mencari dan menggunakan kelas pelaksanaan antara muka ServletContainerInitializer . Ini melibatkan kaedah load ServiceLoader dan prinsip penglihatan loader kelas. Sesetengah orang mempersoalkan pendekatan ini melanggar prinsip penglihatan pemuat kelas, jadi mari kita menganalisisnya secara mendalam.

Artikel menunjukkan bahawa kaedah ServiceLoader.load akhirnya dimuatkan oleh sun.misc.Launcher.AppClassLoader untuk memuatkan kelas pelaksanaan antara muka ServletContainerInitializer . Dalam kod, ServiceLoader.load(service, cl) menggunakan Thread.currentThread().getContextClassLoader() untuk mendapatkan loader kelas. Dalam pelayan aplikasi seperti Tomcat, loader kelas ini biasanya AppClassLoader .

Sesetengah orang berfikir bahawa ServiceLoader.load(service, cl) bersamaan dengan ServiceLoader.load(service, null) . Walaupun hasilnya sama dalam beberapa kes, prinsipnya berbeza. Bekas yang secara eksplisit menentukan loader kelas, sementara yang terakhir menggunakan loader kelas pemanggil.

Kenapa ada yang menganggap ini memecahkan prinsip penglihatan pemuat kelas? Kuncinya terletak pada kekhususan mekanisme SPI. Antara muka dalam rt.jar dimuatkan oleh BootstrapClassLoader , tetapi kelas pelaksanaannya biasanya di ClassPath dan dimuatkan oleh AppClassLoader . BootstrapClassLoader tidak boleh dimuat ke bawah, jadi loader kelas konteks benang perlu memuat kelas pelaksanaan. Ini memintas hierarki yang ketat model delegasi induk, yang membolehkan AppClassLoader memuat kelas yang BootstrapClassLoader tidak dapat dimuatkan. Walaupun masalah itu diselesaikan, ia juga menyimpang dari niat asal model delegasi induk.

Perlu ditekankan bahawa AppClassLoader tidak secara langsung melangkau kod mekanisme delegasi induk, dan ia masih mengikuti logik delegasi induk secara dalaman. Ia hanya dalam senario SPI yang disebabkan oleh batasan BootstrapClassLoader , kerja pemuatan akhir dilakukan oleh AppClassLoader , yang merupakan perdagangan. Mekanisme JDBC adalah serupa. Java hanya menyediakan antara muka. Pelaksanaan khusus disediakan oleh pengilang, dan sekatan mekanisme delegasi induk juga diperlukan untuk memintas.

Oleh itu, mekanisme SPI "melanggar" peraturan ketat model delegasi induk sedikit sebanyak, tetapi ini adalah kompromi yang diperlukan dan tidak sepenuhnya "memusnahkan" prinsip penglihatan pemuat kelas. Ia mendapati cara yang sesuai untuk memuat kelas pelaksanaan melalui loader kelas konteks thread.

Atas ialah kandungan terperinci Apabila Tomcat memuat modul Spring-Web, adakah mekanisme SPI benar-benar memusnahkan prinsip penglihatan Java Class Loaders?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Bagaimanakah subsistem loader kelas dalam JVM menyumbang kepada kebebasan platform?Bagaimanakah subsistem loader kelas dalam JVM menyumbang kepada kebebasan platform?Apr 23, 2025 am 12:14 AM

Loader kelas memastikan konsistensi dan keserasian program Java pada platform yang berbeza melalui format fail kelas bersatu, pemuatan dinamik, model delegasi induk dan bytecode bebas platform, dan mencapai kemerdekaan platform.

Adakah pengkompil Java menghasilkan kod khusus platform? Menjelaskan.Adakah pengkompil Java menghasilkan kod khusus platform? Menjelaskan.Apr 23, 2025 am 12:09 AM

Kod yang dihasilkan oleh pengkompil Java adalah platform bebas, tetapi kod yang akhirnya dilaksanakan adalah platform khusus. 1. Kod sumber Java disusun ke dalam bytecode bebas platform. 2. JVM menukar bytecode ke dalam kod mesin untuk platform tertentu, memastikan operasi silang platform tetapi prestasi mungkin berbeza.

Bagaimanakah JVM mengendalikan multithreading pada sistem operasi yang berbeza?Bagaimanakah JVM mengendalikan multithreading pada sistem operasi yang berbeza?Apr 23, 2025 am 12:07 AM

Multithreading adalah penting dalam pengaturcaraan moden kerana ia dapat meningkatkan respons program dan penggunaan sumber dan mengendalikan tugas serentak yang kompleks. JVM memastikan konsistensi dan kecekapan multithreads pada sistem operasi yang berbeza melalui pemetaan benang, mekanisme penjadualan dan mekanisme kunci penyegerakan.

Apakah maksud 'kemerdekaan platform' dalam konteks Java?Apakah maksud 'kemerdekaan platform' dalam konteks Java?Apr 23, 2025 am 12:05 AM

Kemerdekaan platform Java bermaksud bahawa kod yang ditulis boleh dijalankan di mana -mana platform dengan JVM dipasang tanpa pengubahsuaian. 1) Kod sumber Java dikumpulkan ke dalam bytecode, 2) bytecode ditafsirkan dan dilaksanakan oleh JVM, 3) JVM menyediakan fungsi pengurusan memori dan pengumpulan sampah untuk memastikan program berjalan pada sistem operasi yang berbeza.

Bolehkah aplikasi Java masih menghadapi pepijat atau isu khusus platform?Bolehkah aplikasi Java masih menghadapi pepijat atau isu khusus platform?Apr 23, 2025 am 12:03 AM

JavaapplicationscanIndeedencounterplatform-specificissuesdespitethejvm'sabstraction.reasonsinclude: 1) nativecodeandlibraries, 2) operatingsystemdifferences, 3) jvmimplementationsvariations

Bagaimanakah pengkomputeran awan mempengaruhi kepentingan kemerdekaan platform Java?Bagaimanakah pengkomputeran awan mempengaruhi kepentingan kemerdekaan platform Java?Apr 22, 2025 pm 07:05 PM

Pengkomputeran awan dengan ketara meningkatkan kemerdekaan platform Java. 1) Kod Java dikumpulkan ke dalam bytecode dan dilaksanakan oleh JVM pada sistem operasi yang berbeza untuk memastikan operasi silang platform. 2) Gunakan Docker dan Kubernet untuk menggunakan aplikasi Java untuk meningkatkan kebolehgunaan dan skalabiliti.

Apakah peranan yang dimainkan oleh kemerdekaan platform Java dalam penggunaannya yang meluas?Apakah peranan yang dimainkan oleh kemerdekaan platform Java dalam penggunaannya yang meluas?Apr 22, 2025 pm 06:53 PM

Java'splatformindependenceallowsdeveloperstowritecodeonceandrunitonanydeviceorOSwithaJVM.Thisisachievedthroughcompilingtobytecode,whichtheJVMinterpretsorcompilesatruntime.ThisfeaturehassignificantlyboostedJava'sadoptionduetocross-platformdeployment,s

Bagaimanakah teknologi kontena (seperti Docker) mempengaruhi kepentingan kemerdekaan platform Java?Bagaimanakah teknologi kontena (seperti Docker) mempengaruhi kepentingan kemerdekaan platform Java?Apr 22, 2025 pm 06:49 PM

Teknologi kontena seperti Docker meningkatkan daripada menggantikan kemerdekaan platform Java. 1) Memastikan konsistensi di seluruh persekitaran, 2) Menguruskan kebergantungan, termasuk versi JVM tertentu, 3) memudahkan proses penempatan untuk menjadikan aplikasi Java lebih mudah disesuaikan dan boleh diurus.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.