


Lorsque Tomcat charge les modules de Spring-Web, le mécanisme SPI détruit-il vraiment le principe de visibilité des chargeurs de classe Java?
Apr 19, 2025 pm 02:18 PMChargement du module Tomcat et Spring-Web: analyse du comportement de chargement des classes sous le mécanisme SPI
Lorsque TomCat charge le module Spring-Web, il utilise le mécanisme Java SPI (Interface du fournisseur de services) pour trouver et utiliser ServletContainerInitializer
. Cela implique la méthode load
de ServiceLoader
et le principe de visibilité du chargeur de classe. Certaines personnes remettent en question cette approche viole le principe de visibilité des chargeurs de classe, alors analysons-le en profondeur.
L'article souligne que la méthode ServiceLoader.load
est finalement chargée par sun.misc.Launcher.AppClassLoader
pour charger la classe d'implémentation de ServletContainerInitializer
. Dans le code, ServiceLoader.load(service, cl)
utilise Thread.currentThread().getContextClassLoader()
pour obtenir le chargeur de classe. Dans des serveurs d'applications tels que TomCat, ce chargeur de classe est généralement AppClassLoader
.
Certaines personnes pensent que ServiceLoader.load(service, cl)
équivaut à ServiceLoader.load(service, null)
. Bien que les résultats soient similaires dans certains cas, les principes sont différents. Le premier spécifie explicitement le chargeur de classe, tandis que le second utilise le chargeur de classe de l'appelant.
Pourquoi quelqu'un pense-t-il que cela brise le principe de visibilité des chargeurs de classe? La clé réside dans la particularité du mécanisme SPI. L'interface de rt.jar
est chargée par BootstrapClassLoader
, mais sa classe d'implémentation est généralement dans ClassPath et est chargée par AppClassLoader
. BootstrapClassLoader
ne peut pas être chargé vers le bas, donc le chargeur de classe de contexte de thread doit charger la classe d'implémentation. Cela contourne la hiérarchie stricte du modèle de délégation parent, permettant AppClassLoader
de charger des classes que BootstrapClassLoader
ne peut pas charger. Bien que le problème ait été résolu, il a également dévié de l'intention d'origine du modèle de délégation parent.
Il convient de souligner que AppClassLoader
ne saute pas directement le code du mécanisme de délégation parent, et il suit toujours la logique de délégation parent en interne. Ce n'est que dans le scénario SPI que, en raison des limites de BootstrapClassLoader
, le travail de chargement final est effectué par AppClassLoader
, qui est un compromis. Le mécanisme JDBC est similaire. Java fournit uniquement des interfaces. La mise en ?uvre spécifique est fournie par le fabricant, et les restrictions du mécanisme de délégation parent sont également nécessaires pour contourner.
Par conséquent, le mécanisme SPI "viole" les règles strictes du modèle de délégation des parents dans une certaine mesure, mais il s'agit d'un compromis nécessaire et ne "détruit pas complètement" le principe de visibilité des chargeurs de classe. Il trouve un moyen approprié de charger la classe d'implémentation via le chargeur de classe de contexte de thread.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

La méthode principale de création de fonctions de partage social dans PHP est de générer dynamiquement des liens de partage qui répondent aux exigences de chaque plate-forme. 1. Obtenez d'abord la page actuelle ou les informations d'URL et d'article spécifiées; 2. Utilisez UrLencode pour coder les paramètres; 3. épisser et générer des liens de partage en fonction des protocoles de chaque plate-forme; 4. Afficher les liens sur l'avant pour que les utilisateurs puissent cliquer et partager; 5. Générez dynamiquement des balises OG sur la page pour optimiser l'affichage du contenu du partage; 6. Assurez-vous d'échapper à la saisie des utilisateurs pour empêcher les attaques XSS. Cette méthode ne nécessite pas d'authentification complexe, a de faibles co?ts de maintenance et convient à la plupart des besoins de partage de contenu.

Pour réaliser la correction d'erreur de texte et l'optimisation de la syntaxe avec l'IA, vous devez suivre les étapes suivantes: 1. Sélectionnez un modèle ou une API d'IA appropriée, tels que Baidu, Tencent API ou bibliothèque NLP open source; 2. Appelez l'API via Curl ou Guzzle de PHP et traitez les résultats de retour; 3. Afficher les informations de correction d'erreur dans l'application et permettre aux utilisateurs de choisir d'adopter l'adoption; 4. Utilisez PHP-L et PHP_CODESNIFFER pour la détection de syntaxe et l'optimisation du code; 5. Collectez en continu les commentaires et mettez à jour le modèle ou les règles pour améliorer l'effet. Lorsque vous choisissez AIAPI, concentrez-vous sur l'évaluation de la précision, de la vitesse de réponse, du prix et du support pour PHP. L'optimisation du code doit suivre les spécifications du PSR, utiliser le cache raisonnablement, éviter les requêtes circulaires, revoir le code régulièrement et utiliser x

L'entrée vocale de l'utilisateur est capturée et envoyée au backend PHP via l'API MediaRecorder du JavaScript frontal; 2. PHP enregistre l'audio en tant que fichier temporaire et appelle STTAPI (tel que Google ou Baidu Voice Recognition) pour le convertir en texte; 3. PHP envoie le texte à un service d'IA (comme Openaigpt) pour obtenir une réponse intelligente; 4. PHP appelle ensuite TTSAPI (comme Baidu ou Google Voice Synthesis) pour convertir la réponse en fichier vocal; 5. PHP diffuse le fichier vocal vers l'avant pour jouer, terminant l'interaction. L'ensemble du processus est dominé par PHP pour assurer une connexion transparente entre toutes les liens.

Les dix principales plateformes de marché de crypto-monnaie et d'analyse de données faisant autorité en 2025 sont: 1. CoinmarketCap, fournissant des classements de capitalisation boursière complets et des données de marché de base; 2. Coingecko, fournissant une évaluation de projet multidimensionnelle avec des scores d'indépendance et de confiance; 3. TradingView, ayant les cartes K-Line les plus professionnelles et les outils d'analyse technique; 4. Marché de la binance, fournissant les données les plus directes en temps réel comme le plus grand échange; 5. Marché d'Ouyi, mettant en évidence des indicateurs dérivés clés tels que le volume de position et le taux de capital; 6. Glassnode, en se concentrant sur les données sur cha?ne telles que les adresses actives et les tendances des baleines géantes; 7. Messari, fournissant des rapports de recherche au niveau institutionnel et des données strictes strictes; 8. Cryptocompa

Cet article élabore sur deux méthodes principales pour réaliser Call Hold et Unbanding in Twilio. L'option préférée est de tirer parti de la fonctionnalité de conférence de Twilio pour activer facilement la rétention et la récupération des appels en mettant à jour les ressources des participants de la conférence et pour personnaliser la rétention musicale. Une autre approche consiste à traiter les jambes d'appel indépendantes, qui nécessitent une logique Twiml plus complexe, passée et arrivée la gestion, mais qui est plus lourde que le mode de réunion. L'article fournit des exemples de code spécifiques et des étapes de fonctionnement pour aider les développeurs à implémenter efficacement le contr?le des appels Twilio.

Ethereum est une plate-forme d'application décentralisée basée sur des contrats intelligents, et son ETH de token natif peut être obtenu de diverses manières. 1. Enregistrez un compte via des plateformes centralisées telles que Binance et OUYIOK, complétez la certification KYC et achetez ETH avec des stablecoins; 2. Connectez-vous au stockage numérique via des plates-formes décentralisées et échangez directement ETH avec des stablescoins ou d'autres jetons; 3. Participer à un engagement de réseau et vous pouvez choisir un engagement indépendant (nécessite 32 ETH), des services de gage liquide ou un engagement en un clic sur la plate-forme centralisée pour obtenir des récompenses; 4. Gagnez ETH en fournissant des services aux projets Web3, en effectuant des taches ou en obtenant des Airdrops. Il est recommandé que les débutants partent des plates-formes centralisées traditionnelles, passent progressivement vers des méthodes décentralisées et attachent toujours de l'importance à la sécurité des actifs et à la recherche indépendante, à

Les outils les plus appropriés pour interroger les marchés des stables en 2025 sont: 1. Binance, avec des données faisant autorité et des paires de trading riches, et des graphiques de tradingview intégrés adaptés à une analyse technique; 2. Ouyi, avec une interface claire et une forte intégration fonctionnelle, et prend en charge le fonctionnement unique des comptes Web3 et Defi; 3. CoinmarketCap, avec de nombreuses devises, et le secteur des stablescoin peut afficher le classement des valeurs de marché et les doyens; 4. Coingecko, avec des dimensions de données complètes, fournit des scores de confiance et des indicateurs d'activité communautaire, et a une position neutre; 5. Huobi (HTX), avec des conditions de marché stables et des opérations amicales, adaptées aux demandes d'actifs traditionnelles; 6. Gate.io, avec la collection la plus rapide de nouvelles pièces de monnaie et de niche, et est le premier choix pour les projets pour explorer le potentiel; 7. tra

L'utilisation réelle de Battle Royale dans le système de double monnaie ne s'est pas encore produite. Conclusion En ao?t 2023, l'étincelle du protocole de prêt écologique Makerdao a donné un rendement annualisé de Dai8% $. Ensuite, Sun Chi est entré en lots, investissant un total de 230 000 $ Steth, représentant plus de 15% des dép?ts de Spark, for?ant Makerdao à faire une proposition d'urgence pour réduire le taux d'intérêt à 5%. L'intention initiale de Makerdao était de "subventionner" le taux d'utilisation de $ dai, devenant presque le rendement en solo de Justin Sun. Juillet 2025, Ethe
