Rumah Java javaTutorial Apabila 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?

Apr 19, 2025 pm 02:18 PM
bootstrap tomcat ai kenapa

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 Laman Web ini
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

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

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah sepuluh aplikasi perdagangan mata wang maya teratas? Kedudukan pertukaran mata wang digital terkini Apakah sepuluh aplikasi perdagangan mata wang maya teratas? Kedudukan pertukaran mata wang digital terkini Apr 28, 2025 pm 08:03 PM

Sepuluh pertukaran mata wang digital teratas seperti Binance, OKX, Gate.io telah meningkatkan sistem mereka, urus niaga yang pelbagai dan langkah -langkah keselamatan yang ketat.

Harga Bitcoin hari ini Harga Bitcoin hari ini Apr 28, 2025 pm 07:39 PM

Perubahan harga Bitcoin hari ini terjejas oleh banyak faktor seperti makroekonomi, dasar, dan sentimen pasaran. Pelabur perlu memberi perhatian kepada analisis teknikal dan asas untuk membuat keputusan yang tepat.

Platform perdagangan mata wang teratas yang manakah di dunia adalah versi terbaru dari Platform Perdagangan Top Top Top Platform perdagangan mata wang teratas yang manakah di dunia adalah versi terbaru dari Platform Perdagangan Top Top Top Apr 28, 2025 pm 08:09 PM

Sepuluh platform perdagangan cryptocurrency teratas di dunia termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi Global, Bitfinex, Bittrex, Kucoin dan Poloniex, yang semuanya menyediakan pelbagai kaedah perdagangan dan langkah -langkah keselamatan yang kuat.

Bagaimana cara menggunakan Perpustakaan Chrono di C? Bagaimana cara menggunakan Perpustakaan Chrono di C? Apr 28, 2025 pm 10:18 PM

Menggunakan perpustakaan Chrono di C membolehkan anda mengawal selang masa dan masa dengan lebih tepat. Mari kita meneroka pesona perpustakaan ini. Perpustakaan Chrono C adalah sebahagian daripada Perpustakaan Standard, yang menyediakan cara moden untuk menangani selang waktu dan masa. Bagi pengaturcara yang telah menderita dari masa. H dan CTime, Chrono tidak diragukan lagi. Ia bukan sahaja meningkatkan kebolehbacaan dan mengekalkan kod, tetapi juga memberikan ketepatan dan fleksibiliti yang lebih tinggi. Mari kita mulakan dengan asas -asas. Perpustakaan Chrono terutamanya termasuk komponen utama berikut: STD :: Chrono :: System_Clock: Mewakili jam sistem, yang digunakan untuk mendapatkan masa semasa. Std :: Chron

Berapa bernilai bitcoin Berapa bernilai bitcoin Apr 28, 2025 pm 07:42 PM

Harga Bitcoin berkisar antara $ 20,000 hingga $ 30,000. 1. Harga Bitcoin telah berubah secara dramatik sejak tahun 2009, mencapai hampir $ 20,000 pada tahun 2017 dan hampir $ 60,000 pada tahun 2021. Harga dipengaruhi oleh faktor -faktor seperti permintaan pasaran, bekalan, dan persekitaran makroekonomi. 3. Dapatkan harga masa nyata melalui pertukaran, aplikasi mudah alih dan laman web. 4. Harga Bitcoin sangat tidak menentu, didorong oleh sentimen pasaran dan faktor luaran. 5. Ia mempunyai hubungan tertentu dengan pasaran kewangan tradisional dan dipengaruhi oleh pasaran saham global, kekuatan dolar AS, dan sebagainya. 6. Trend jangka panjang adalah yakin, tetapi risiko perlu dinilai dengan berhati-hati.

Platform perdagangan mata wang teratas yang manakah di dunia adalah antara sepuluh platform perdagangan mata wang teratas pada tahun 2025 Platform perdagangan mata wang teratas yang manakah di dunia adalah antara sepuluh platform perdagangan mata wang teratas pada tahun 2025 Apr 28, 2025 pm 08:12 PM

Sepuluh pertukaran cryptocurrency teratas di dunia pada tahun 2025 termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi, Bitfinex, Kucoin, Bittrex dan Poloniex, yang semuanya dikenali dengan jumlah dan keselamatan perdagangan mereka yang tinggi.

Cara Memilih Platform Perdagangan Bitcoin yang patuh dan selamat Cara Memilih Platform Perdagangan Bitcoin yang patuh dan selamat Apr 28, 2025 pm 05:42 PM

Apabila memilih platform perdagangan Bitcoin yang mematuhi dan selamat, anda perlu menilai lesen pengawalseliaannya, dasar KYC/AML dan langkah -langkah keselamatan, dan mengesyorkan tiga platform utama: Binance, OKX dan Gate.io.

10 teratas yang biasa digunakan dalam kedudukan perisian perdagangan cryptocurrency pada tahun 2025 10 teratas yang biasa digunakan dalam kedudukan perisian perdagangan cryptocurrency pada tahun 2025 Apr 28, 2025 pm 05:45 PM

Kedudukan Perisian Perdagangan Cryptocurrency Top pada tahun 2025 termasuk Binance, OKX, Gate.io, dan lain -lain, yang semuanya menyediakan pelbagai mod perdagangan dan langkah -langkah keselamatan yang ketat.

See all articles