Le mécanisme d'injection de dépendance de Spring est principalement
basé sur le type , pas les noms. Lors de la rencontre de plusieurs types du même type (comme TenantDataSource), il ne reviendra pas automatiquement pour correspondre en fonction du nom du paramètre. En effet, Spring ne peut pas toujours garantir le nom du paramètre dans la méthode pour correspondre au nom de bean.
Java par défaut,ne conservera pas le nom du paramètre dans le bytecode compilé. S'il n'y a pas de configuration spéciale, les noms de paramètres (par exemple, TenantAdataSource et TenantBdataSource) seront effacés pendant la compilation et les ont remplacés par des noms universels, tels que Arg0 et Arg1. Par conséquent, le printemps ne peut pas savoir que la locationadatasource fait référence au haricot appelé "Tenanta-Datasource".
Résolvez le problème de rétention du nom de paramètreVous pouvez utiliser le logo du compilateur pour conserver le nom du paramètre dans le code d'octet:
-parameters
<code>javac -parameters MyClass.java</code>
Spring évite les hypothèses pour éviter les accidents. Par exemple, si le nom du paramètre est accidentellement échangé ou nommé, ou si les développeurs s'attendent à des mappages différentes, que se passera-t-il? S'il n'y a pas de guidage clair (tel que
), Spring ne peut pas déterminer l'intention du développeur et choisir de lancer une erreur au lieu d'injecter le mauvais haricot.
@Qualifier
Spring suit le principe de "explicitement mieux que caché". L'injection dépendante doit être prévisible et ne dépend pas des hypothèses des noms de paramètres à l'appariement de la correspondance du nom de bean. Le printemps est cohérent dans différents environnements et cadres. Certaines langues ou cadres (tels que Kotlin) conservent le nom du paramètre par défaut, tandis que d'autres langues ne sont pas conservées.
Quand la correspondance du nom peut-elle fonctionner automatiquement?
Bien que Spring ne correspond pas au nom du paramètre par défaut, il peut être égalé en fonction du nom du paramètre dans certains cas, mais cela dépend de vos paramètres:
Spring 4.3 Nom du paramètre Découverte
Si le code de compilation de logo , lorsqu'il y a une ambiguïté, le ressort peut déduire le nom du bean du nom du paramètre.
Exemple:
-parameters
).
<code>@Autowired public TenantService(TenantDataSource tenantADataSource, TenantDataSource tenantBDataSource) { this.tenantADataSource = tenantADataSource; this.tenantBDataSource = tenantBDataSource; }</code>Pourquoi le printemps est-il plus enclin à utiliser @qualificier?
-parameters
Utiliser pour assurer la définition et éliminer l'ambiguïté, afin que les développeurs et les cadres puissent clairement intention. @Qualifier
De cette manière, le printemps peut savoir avec précision quel haricot injecter, quel que soit le nom du paramètre ou d'autres facteurs.
Le ressort devrait être plus intelligent?
Certaines personnes peuvent penser qu'un cadre comme Spring devrait être plus intelligent, et le nom de bean est automatiquement adapté au nom du paramètre lorsqu'il y a une ambiguïté. Mais:
- Compatibilité arrière : La modification automatique de ce comportement peut détruire les applications existantes qui ne correspondent pas au nom du bean et au nom du paramètre. prévisibilité
- : résolvez explicitement l'ambiguïté (par exemple, via ) pour s'assurer que les développeurs savent toujours quel haricot est injecté. Les hypothèses réaclables peuvent causer des difficultés à déboguer, en particulier dans les grandes applications complexes.
@Qualifier
La situation dans la vraie scène
dans la plupart des applications réelles:
Les développeurs utilisent des noms de bean significatifs et des noms de paramètres, mais ils préfèrent également préférer
- pour assurer leur clarté.
-
@Qualifier
pour les scènes multi-exemples, Configurer dynamiquement - ou Méthodes basées en usine (par exemple, abstractroutingatasorce), au lieu de connecter manuellement chaque bean. points clés
Spring First Injects par type
- : S'il n'y a qu'un seul type de bean, le printemps l'injectera sans aucun problème. S'il y a plusieurs haricots du même type, Spring nécessite des invites supplémentaires (telles que
- ) pour résoudre l'ambiguïté.
Le nom du paramètre n'est pas fiable. Même si le nom du paramètre (
@Qualifier
) est conservé, Spring évitera la correspondance de correspondance bien connue, à moins que la configuration ne soit claire. - explicite est meilleur que caché : la considération prioritaire de ressort peut être prévisible et encourage les développeurs à utiliser une configuration explicite (telle que ou
-parameters
) au lieu de compter sur une correspondance cachée. -
Concept de conception de Spring : Les erreurs brumeuses peuvent empêcher les accidents et s'assurer que les développeurs contrôlent pleinement l'injection de dépendance.
@Qualifier
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!

Comment Java atténue des problèmes spécifiques à la plate-forme? Java implémente la plate-forme indépendante de la plate-forme via JVM et des bibliothèques standard. 1) Utilisez Bytecode et JVM pour abstraction des différences du système d'exploitation; 2) La bibliothèque standard fournit des API multiplateformes, telles que les chemins de fichier de traitement des classes de chemins et le codage des caractères de traitement de la classe Charset; 3) Utilisez des fichiers de configuration et des tests multiplateformes dans les projets réels pour l'optimisation et le débogage.

Java'splatformIndependanceNhancesMicRoservices ArchitectureByoFerringDeploymentFlexibilité, cohérence, évolutivité, etportabilité.1) DeploymentFlexibilityAllowsMicroserviceStorUnonanyPlatformwithajvm.2) CohérenceaCossserviceSiceSIGLYPLATFORMWithajvm.2)

Graalvm améliore l'indépendance de la plate-forme de Java de trois manières: 1. Interopérabilité transversale, permettant à Java d'interopérer de manière transparente avec d'autres langues; 2. 3. Optimisation des performances, le compilateur Graal génère un code machine efficace pour améliorer les performances et la cohérence des programmes Java.

ToeffectivetestjavaapplicationsforPlatformCompatibilité, suivi de l'essence: 1) SetUpAutomatedStestingacrossMultipleplatformSusingcitoolslikejenkinsorgithubacts.

Le compilateur Java réalise l'indépendance de la plate-forme de Java en convertissant le code source en bytecode indépendant de la plate-forme, permettant aux programmes Java d'exécuter sur n'importe quel système d'exploitation avec JVM installé.

ByteCodeachievesPlatformIndependanceBeBeingExEcutedByaVirtualmachine (VM), permettant à la codétorunonanyplatformwiththeappo pourpropriév.forexample, javabytecocecanrunonanydevicewithajvm, permettre de "writeonce, runanywhere" fonctionnalité.

Java ne peut pas atteindre l'indépendance de la plate-forme à 100%, mais son indépendance de la plate-forme est implémentée via JVM et ByteCode pour s'assurer que le code s'exécute sur différentes plates-formes. Les implémentations spécifiques incluent: 1. Compilation dans ByteCode; 2. Interprétation et exécution de JVM; 3. Cohérence de la bibliothèque standard. Cependant, les différences de mise en œuvre de JVM, les différences de système d'exploitation et de matériel et la compatibilité des bibliothèques tierces peuvent affecter l'indépendance de sa plate-forme.

Java réalise l'indépendance de la plate-forme via "Écrire une fois, exécuter partout" et améliore la maintenabilité du code: 1. Réutilisation du code élevé et réduit le développement en double; 2. Coût de maintenance faible, une seule modification est requise; 3. L'efficacité de collaboration d'équipe élevée est élevée, pratique pour le partage des connaissances.


Outils d'IA chauds

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.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

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

Article chaud

Outils chauds

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

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

Navigateur d'examen sécurisé
Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.
