


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!

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

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

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

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.

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.

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.

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

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.

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.

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.

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.
