suchen
HeimJavajavaLernprogrammSpring-: WARUM FRING-CANTOT-MATCH-MATCH-BIS-NAME-FÜR-INPORATION

spring-: why-spring-cannot-match-by-name-for-injection

Springabhängigkeitsinjektion: Warum kann sie nicht automatisch mit dem Namen übereinstimmen?

Die Abhängigkeitsinjektionsmechanismus von

Spring betrifft hauptsächlich

auf dem Typ , nicht auf Namen. Bei der Begegnung mehrerer Arten desselben Typs (z. B. MieterDataSource) kehrt es nicht automatisch nach dem Parameternamen zurück. Dies liegt daran, dass der Frühling den Parameternamen in der Methode nicht immer garantieren kann, dass sie mit dem Bean -Namen übereinstimmt.

Java standardmäßig behält

den Parameternamen im kompilierten Bytecode nicht bei. Wenn es keine spezielle Konfiguration gibt, werden die Parameternamen (z. B. TenantadataSource und MieterbdataSource) während der Kompilierung gelöscht und sie durch universelle Namen wie Arg0 und Arg1 ersetzt. Daher kann der Frühling nicht wissen, dass TenantadataSource sich auf die Bean namens "Tenanta-Datasource" bezieht.

Lösen Sie das Problem der Parameternamenretention

Sie können das Compiler -Logo verwenden, um den Parameternamen im Byte -Code beizubehalten: -parameters

<code>javac -parameters MyClass.java</code>
Auch wenn dieses Logo verwendet wird, stimmt die Feder immer noch nicht mit dem Parameternamen überein, es sei denn, die Konfiguration ist klar.

Spring vermeidet Annahmen, um Unfälle zu verhindern. Wenn zum Beispiel der Parametername versehentlich ausgetauscht oder benannt wird oder die Entwickler unterschiedliche Zuordnungen erwarten, was wird dann passieren? Wenn es keine eindeutige Anleitung gibt (z. B.

), kann der Frühling die Absicht des Entwicklers nicht bestimmen und einen Fehler werfen, anstatt die falsche Bohne zu injizieren. @Qualifier

Frühling folgt dem Prinzip von "explizit besser als versteckt". Die abhängige Injektion sollte vorhersehbar sein und hängt nicht von den Annahmen von Parameternamen zur Übereinstimmung der Bean -Name -Matching ab. Der Frühling ist in verschiedenen Umgebungen und Frameworks konsistent. Einige Sprachen oder Frameworks (z. B. Kotlin) behalten den Parameternamen standardmäßig bei, während andere Sprachen nicht beibehalten werden.

Wann kann der Name Match automatisch funktionieren?

Obwohl Spring standardmäßig nicht mit dem Parameternamen übereinstimmt, kann er in einigen Fällen entsprechend dem Parameternamen übereinstimmen, aber es hängt von Ihren Einstellungen ab:

Spring 4.3 Parametername Discover

Wenn der Code Logo -Kompilierung, wenn Unklarheit besteht, kann der Frühling den Namen der Bean aus dem Parameternamen schließen.

-parameters Beispiel:

Wenn die Namen Logo und Parameter (TenantadataSource, MieterbdataSource) und der Bean -Name übereinstimmen, kann der Frühling die Mehrdeutigkeit lösen. Dieses Verhalten ist jedoch in der komplexen Konfiguration nicht immer zuverlässig oder vorhersehbar, weshalb die bevorzugte Anzeigekonfiguration (wie

).
<code>@Autowired
public TenantService(TenantDataSource tenantADataSource, TenantDataSource tenantBDataSource) {
    this.tenantADataSource = tenantADataSource;
    this.tenantBDataSource = tenantBDataSource;
}</code>

Warum neigt Frühling eher, @Qualifier zu verwenden? -parameters @Qualifier Verwenden Sie , um die Definition zu gewährleisten und Mehrdeutigkeiten zu beseitigen, damit sowohl Entwickler als auch Frameworks eindeutig beabsichtigt werden können.

Beispiel:

Auf diese Weise kann der Frühling unabhängig vom Parameternamen oder anderen Faktoren genau wissen, welche Bean injizieren soll. @Qualifier

Spring sollte schlauer sein?

Einige Leute mögen denken, dass ein Framework wie Spring intelligenter sein sollte und der Bean -Name automatisch mit dem Parameternamen übereinstimmt, wenn Unklarheit besteht. Aber:

  1. Zurück -Kompatibilität : Das automatische Ändern dieses Verhaltens kann die vorhandenen Anwendungen zerstören, die nicht mit dem Namen des Bean und dem Parameternamen übereinstimmen.
  2. Vorhersagbarkeit
  3. : Lösen Sie explizit die Mehrdeutigkeit (z. B. durch ), um sicherzustellen, dass Entwickler immer wissen, welche Bean injiziert wird. Reaktive Annahmen können zu Schwierigkeiten beim Debuggen führen, insbesondere in großen komplexen Anwendungen. @Qualifier
  4. Die Situation in der realen Szene

In den meisten tatsächlichen Anwendungen:

Entwickler verwenden aussagekräftige Bean -Namen und Parameternamen, bevorzugen jedoch auch
    , um ihre Klarheit zu gewährleisten.
  • @Qualifier Für Multi -Example -Szenen konfigurieren Sie
  • dynamisch
  • oder fabrikbasierte Methoden (z. B. AbstractroutingataSorce), anstatt jede Bean manuell zu verbinden.
  • Schlüsselpunkte

Feder injects nach Typ

    : Wenn es nur eine Bean -Art gibt, wird die Frühling es ohne Probleme injiziert. Wenn mehrere Bohnen desselben Typs vorhanden sind, erfordert die Feder zusätzliche Eingabeaufforderungen (z. B.
  1. ), um Mehrdeutigkeiten zu lösen. Der Parametername ist nicht zuverlässig. Selbst wenn der Parametername (@Qualifier) beibehalten wird, vermeidet die Feder die gut bekannte Übereinstimmung, sofern die Konfiguration nicht klar ist.
  2. explizit ist besser als versteckt : Die Berücksichtigung der Frühlingspriorität kann vorhersehbar sein und ermutigt Entwickler, eine explizite Konfiguration (wie oder -parameters) zu verwenden, anstatt sich auf versteckte Übereinstimmungen zu verlassen.
  3. Spring Design Concept : Nebelfehler können Unfälle verhindern und sicherstellen, dass Entwickler die Abhängigkeitsinjektion vollständig steuern. @Qualifier

Das obige ist der detaillierte Inhalt vonSpring-: WARUM FRING-CANTOT-MATCH-MATCH-BIS-NAME-FÜR-INPORATION. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Wie trägt der JVM zu Javas 'Schreiben Sie einmal, rennen Sie irgendwohin' (Wora) Fähigkeit?Wie trägt der JVM zu Javas 'Schreiben Sie einmal, rennen Sie irgendwohin' (Wora) Fähigkeit?May 02, 2025 am 12:25 AM

JVM implementiert die Wora-Merkmale von Java durch Bytecode-Interpretation, plattformunabhängige APIs und dynamische Klassenbelastung: 1. Bytecode wird als Maschinencode interpretiert, um einen plattformübergreifenden Betrieb sicherzustellen. 2. Unterschiede zwischen API -abstrakter Betriebssystem; 3. Die Klassen werden zur Laufzeit dynamisch geladen, um eine Konsistenz zu gewährleisten.

Wie adressieren neuere Versionen von Java plattformspezifische Probleme?Wie adressieren neuere Versionen von Java plattformspezifische Probleme?May 02, 2025 am 12:18 AM

Die neueste Version von Java löst effektiv plattformspezifische Probleme durch JVM-Optimierung, Standardbibliotheksverbesserungen und Unterstützung von Drittanbietern. 1) JVM -Optimierung, wie der ZGC von Java11, verbessert die Leistung der Müllsammlung. 2) Standardbibliotheksverbesserungen wie das Modulsystem von Java9, das plattformbedingte Probleme reduziert. 3) Bibliotheken von Drittanbietern bieten plattformoptimierte Versionen wie OpenCV.

Erläutern Sie den von der JVM durchgeführten Bytecode -Überprüfungsprozess.Erläutern Sie den von der JVM durchgeführten Bytecode -Überprüfungsprozess.May 02, 2025 am 12:18 AM

Der Bytecode -Überprüfungsprozess des JVM enthält vier wichtige Schritte: 1) Überprüfen Sie, ob das Klassendateiformat den Spezifikationen entspricht, 2) Überprüfen Sie die Gültigkeit und Korrektheit der Bytecode -Anweisungen, 3) die Datenflussanalyse durchführen, um die Sicherheitstypsicherheit zu gewährleisten, und 4) Ausgleich der gründlichen Überprüfung und Leistung der Verifizierung. Durch diese Schritte stellt die JVM sicher, dass nur sichere, korrekte Bytecode ausgeführt wird, wodurch die Integrität und Sicherheit des Programms geschützt wird.

Wie vereinfacht die Unabhängigkeit von Plattform die Bereitstellung von Java -Anwendungen?Wie vereinfacht die Unabhängigkeit von Plattform die Bereitstellung von Java -Anwendungen?May 02, 2025 am 12:15 AM

Java'SplatformIndependenCealLowsApplicationStorunonanyoperatingsystemWithajvm.1) SinglecodeBase: WriteAndCompileonceForAllpatforms.2) EasyUpdates: UpdateByteCodeForsimultaneousDeployment.3) TestingEffizienz: testononePlatformForaNeunveralbehavior

Wie hat sich die Unabhängigkeit von Java im Laufe der Zeit entwickelt?Wie hat sich die Unabhängigkeit von Java im Laufe der Zeit entwickelt?May 02, 2025 am 12:12 AM

Die Unabhängigkeit von Java wird durch Technologien wie JVM, JIT -Zusammenstellung, Standardisierung, Generika, Lambda -Ausdrücke und Projektpanama kontinuierlich verbessert. Seit den neunziger Jahren hat sich Java von Basic JVM zu hoher Leistung moderner JVM entwickelt, um die Konsistenz und Effizienz des Codes über verschiedene Plattformen hinweg zu gewährleisten.

Was sind einige Strategien, um plattformspezifische Probleme in Java-Anwendungen zu mildern?Was sind einige Strategien, um plattformspezifische Probleme in Java-Anwendungen zu mildern?May 01, 2025 am 12:20 AM

Wie lindert Java plattformspezifische Probleme? Java implementiert plattformunabhängig über JVM- und Standardbibliotheken. 1) Bytecode und JVM verwenden, um die Unterschiede für das Betriebssystem abstrahieren; 2) Die Standardbibliothek bietet plattformübergreifende APIs wie Pfade der Klassenverarbeitungsdateien und die Codierung von Charset Class Processing. 3) Verwenden Sie Konfigurationsdateien und Multi-Plattform-Tests in tatsächlichen Projekten zur Optimierung und Debuggierung.

Wie ist die Beziehung zwischen der Unabhängigkeit der Java -Plattform und der Microservices -Architektur?Wie ist die Beziehung zwischen der Unabhängigkeit der Java -Plattform und der Microservices -Architektur?May 01, 2025 am 12:16 AM

Java'SplatformIndependenceEnhancesMicroservicesArchitecture byFeringDeploymentFlexibilität, Konsistenz, Skalierbarkeit und Portabilität.1) EinsatzFlexibilitätsmarkroservicestorunonanyplatformwithajvm.2) konsistenzacrossservicessimplimplimplifiesDevention und

Wie bezieht sich Graalvm auf die Unabhängigkeitsziele der Plattform von Java?Wie bezieht sich Graalvm auf die Unabhängigkeitsziele der Plattform von Java?May 01, 2025 am 12:14 AM

Graalvm verbessert die Unabhängigkeit der Java-Plattform auf drei Arten: 1. Cross-Sprach-Interoperabilität und ermöglicht es Java, nahtlos mit anderen Sprachen zusammenzuarbeiten; 2. Unabhängige Laufzeitumgebung, kompilieren Sie Java -Programme in lokale ausführbare Dateien über GraalvmnativeImage; 3. Die Leistungsoptimierung generiert Graal Compiler einen effizienten Maschinencode, um die Leistung und Konsistenz von Java -Programmen zu verbessern.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version