Spring-:なぜspring-cannot-match-by-name-for-injection
Springの依存関係注入メカニズムは、主に名前ではなくタイプ
に基づいています。同じタイプの複数のタイプ(TenantDataSourceなど)に遭遇した場合、パラメーター名に従って一致するように自動的に戻りません。これは、Springがメソッドのパラメーター名をBean名と一致させることができると常に保証できるとは限らないためです。 javaデフォルトでは、
は、コンパイルされたbytecodeでパラメーター名を保持しません。特別な構成がない場合、パラメーター名(たとえば、tenantadatasourceやtenantbdatasource)が編集中にクリアされ、arg0やarg1などのユニバーサル名に置き換えられます。 したがって、春はTenantadatasourceが「Tenanta-Datasource」と呼ばれる豆を指していることを知ることができません。 パラメーター名保持問題を解きます
コンパイラロゴを使用して、バイトコードにパラメーター名を保持できます。
このロゴが使用されている場合でも、Springは構成がクリアされていない限り、パラメーター名と一致しません。 -parameters
<code>javac -parameters MyClass.java</code>
スプリングは、「隠されたよりも明示的に優れている」という原則に従います。依存噴射は予測可能であるべきであり、パラメーター名の仮定の仮定に依存しないでください。春は、さまざまな環境とフレームワークで一貫しています。一部の言語またはフレームワーク(Kotlinなど)は、デフォルトでパラメーター名を保持しますが、他の言語は保持されません。
@Qualifier
名前の一致はいつ自動的に動作できますか?
ロゴがコードをコンパイルする場合、あいまいさがある場合、springはパラメーター名から豆の名前を推測できます。
例:
ロゴとパラメーター名(TenantadataSource、TenantBDataSource)とBean Nameが一致している場合、Springは曖昧さを解くことができます。ただし、この動作は、複雑な構成では常に信頼性があるか予測可能ではないため、優先表示構成(
など)が優先されます。
-parameters
なぜスプリングは @qualifierを使用する傾向があるのですか?
を使用して、開発者とフレームワークの両方が明確に意図できるように、定義を確保し、曖昧さを排除します。
<code>@Autowired public TenantService(TenantDataSource tenantADataSource, TenantDataSource tenantBDataSource) { this.tenantADataSource = tenantADataSource; this.tenantBDataSource = tenantBDataSource; }</code>
この方法では、パラメーター名やその他の要因に関係なく、スプリングは注入する豆を正確に知ることができます。 -parameters
春はより賢いはずですか?
スプリングのようなフレームワークはよりインテリジェントであるべきだと考える人もいれば、あいまいさがあるときにビーン名はパラメーター名と自動的に一致すると考えるかもしれません。しかし、:
- back互換性:この動作を自動的に変更すると、Bean名とパラメーター名と一致しない既存のアプリケーションが破壊される場合があります。 予測可能性
- :曖昧さ(たとえば、)を明示的に解決して、開発者がどのBeanが注入されているかを常に把握できるようにします。特に大規模な複雑なアプリケーションでは、再設計可能な仮定がデバッグを引き起こす可能性があります。
@Qualifier
実際のシーンの状況
:
開発者は、意味のあるBean名とパラメーター名を使用しますが、明確さを確保するために
- を好むことも好みます。
-
マルチエクサムシーンの場合、各豆を手動で接続するのではなく、
@Qualifier
Factoryベースのメソッド(例:Abstractroutingatasorce)を動的に構成します。 -
キーポイント
spring最初の注入
など)が必要です。
- パラメーター名は信頼できません
- :デフォルトでは、パラメーター名はJavaバイトコードに保持されないため、パラメーターをパラメーターと一致させるためにそれらを使用できません。パラメーター名()が保持されている場合でも、Springは構成が明確でない限り、よく知られているマッチングマッチングを回避します。
@Qualifier
明示的は隠されたよりも優れています :春の優先度の考慮が予測可能であり、開発者は隠されたマッチングに依存するのではなく、明示的な構成( - やなど)を使用するように促します。
-parameters
Springのデザインコンセプト
:霧のエラーは事故を防ぎ、開発者が依存注入を完全に制御できるようにします。
以上がSpring-:なぜspring-cannot-match-by-name-for-injectionの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











一部のアプリケーションが適切に機能しないようにする会社のセキュリティソフトウェアのトラブルシューティングとソリューション。多くの企業は、内部ネットワークセキュリティを確保するためにセキュリティソフトウェアを展開します。 ...

多くのアプリケーションシナリオでソートを実装するために名前を数値に変換するソリューションでは、ユーザーはグループ、特に1つでソートする必要がある場合があります...

システムドッキングでのフィールドマッピング処理は、システムドッキングを実行する際に難しい問題に遭遇することがよくあります。システムのインターフェイスフィールドを効果的にマッピングする方法A ...

intellijideaultimatiateバージョンを使用してスプリングを開始します...

データベース操作にMyBatis-Plusまたはその他のORMフレームワークを使用する場合、エンティティクラスの属性名に基づいてクエリ条件を構築する必要があることがよくあります。あなたが毎回手動で...

Javaオブジェクトと配列の変換:リスクの詳細な議論と鋳造タイプ変換の正しい方法多くのJava初心者は、オブジェクトのアレイへの変換に遭遇します...

eコマースプラットフォーム上のSKUおよびSPUテーブルの設計の詳細な説明この記事では、eコマースプラットフォームでのSKUとSPUのデータベース設計の問題、特にユーザー定義の販売を扱う方法について説明します。

Redisキャッシュソリューションは、製品ランキングリストの要件をどのように実現しますか?開発プロセス中に、多くの場合、ランキングの要件に対処する必要があります。
