Spring Boot の @Qualifier アノテーションは、同じ型の Bean が複数あるが、特定の Bean を注入したい場合のあいまいさを解決するために使用されます。これは、複数の候補が存在する場合に Spring がどの Bean を自動配線するかを決定するのに役立ちます。
@Qualifier が役立つ一般的なシナリオをすべて例とともに示します。
シナリオ 1: 同じタイプの複数の Bean
同じタイプの Bean が複数ある場合、特定の Bean を注入したいとします。
例:
import org.springframework.stereotype.Component; @Component public class Dog implements Animal { @Override public String sound() { return "Bark"; } } @Component public class Cat implements Animal { @Override public String sound() { return "Meow"; } }
ここでは、Dog と Cat の両方が Animal インターフェースを実装しています。
@Qualifier の使用法:
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Service; @Service public class AnimalService { private final Animal animal; @Autowired public AnimalService(@Qualifier("cat") Animal animal) { this.animal = animal; } public String getAnimalSound() { return animal.sound(); } }
この例では、 @Qualifier("cat") アノテーションは、Cat Bean を AnimalService に注入する必要があることを指定しています。 @Qualifier がないと、Spring はあいまいさのために例外をスローします。
シナリオ 2: プライマリ Bean とセカンダリ Bean で @Qualifier を使用する
場合によっては、1 つの「プライマリ」Bean と、あまり使用されないその他の Bean がある場合でも、@Qualifier を使用して特定の Bean を注入できるようにしたい場合があります。
例:
@Component @Primary public class Dog implements Animal { @Override public String sound() { return "Bark"; } } @Component public class Cat implements Animal { @Override public String sound() { return "Meow"; } }
@primary アノテーションにより、デフォルトで Dog が確実に挿入されます。ただし、@Qualifier を使用して Cat を挿入することはできます。
@primary をオーバーライドするための @Qualifier の使用:
@Service public class AnimalService { private final Animal animal; @Autowired public AnimalService(@Qualifier("cat") Animal animal) { this.animal = animal; } public String getAnimalSound() { return animal.sound(); } }
この場合、Dog が @primary としてマークされているにもかかわらず、@Qualifier アノテーションにより Cat Bean が挿入されます。
シナリオ 3: コンストラクター インジェクションとフィールド インジェクションを使用した @Qualifier
@Qualifier は、コンストラクターベースとフィールドベースの両方の注入で使用できます。
例: @Qualifier を使用したフィールド注入:
@Service public class AnimalService { @Autowired @Qualifier("dog") private Animal animal; public String getAnimalSound() { return animal.sound(); } }
この場合、@Qualifier("dog") により、Dog Bean が AnimalService に確実に挿入されます。
シナリオ 4: メソッド パラメーター インジェクションを使用した @Qualifier
メソッドのパラメーターを介して依存関係を注入するときに @Qualifier を使用することもできます。
例:
@Service public class AnimalService { private Animal animal; @Autowired public void setAnimal(@Qualifier("dog") Animal animal) { this.animal = animal; } public String getAnimalSound() { return animal.sound(); } }
ここで、 @Qualifier("dog") は、Dog Bean がセッター メソッドを通じて挿入されることを保証します。
シナリオ 5: カスタム アノテーションを使用した @Qualifier
カスタム修飾子を作成して Bean 名のハードコーディングを回避し、コードをクリーンにして保守しやすくすることができます。
例: カスタム修飾子:
カスタム修飾子の作成:
import org.springframework.beans.factory.annotation.Qualifier; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; @Qualifier @Retention(RetentionPolicy.RUNTIME) public @interface DogQualifier { }
カスタム修飾子を適用します:
@Component @DogQualifier public class Dog implements Animal { @Override public String sound() { return "Bark"; } } @Component public class Cat implements Animal { @Override public String sound() { return "Meow"; } }
カスタム修飾子を使用して挿入:
@Service public class AnimalService { private final Animal animal; @Autowired public AnimalService(@DogQualifier Animal animal) { this.animal = animal; } public String getAnimalSound() { return animal.sound(); } }
この例では、@Qualifier("dog") を使用する代わりに、@DogQualifier を使用して、注入する Bean を指定します。
シナリオ 6: コレクション内の @Qualifier
Bean のコレクションを自動配線するときに @Qualifier を使用して、特定の Bean のみが確実に挿入されるようにすることができます。
例:
import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; @Component @Qualifier("domestic") public class Dog implements Animal { @Override public String sound() { return "Bark"; } } @Component @Qualifier("domestic") public class Cat implements Animal { @Override public String sound() { return "Meow"; } } @Component public class Lion implements Animal { @Override public String sound() { return "Roar"; } }
コレクションでの使用:
@Service public class AnimalService { private final List<animal> animals; @Autowired public AnimalService(@Qualifier("domestic") List<animal> animals) { this.animals = animals; } public void printAnimalSounds() { animals.forEach(animal -> System.out.println(animal.sound())); } } </animal></animal>
この例では、@Qualifier("domestic") でマークされているため、Dog Bean と Cat Bean のみが挿入されます。
概要:
@Qualifier は、同じタイプの候補が複数ある場合に特定の Bean を注入するのに役立ちます。
コンストラクター インジェクション、フィールド インジェクション、メソッド インジェクション、カスタム修飾子などのシナリオで使用され、コレクションでも使用されます。
これらのシナリオを理解することで、@Qualifier を効果的に使用して曖昧さを解決し、Spring Boot アプリケーションで Bean インジェクションを管理できるようになります。
以上が@Qualifier アノテーション Spring Boot の説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Javaはプラットフォーム固有の問題をどのように軽減しますか? Javaは、JVMおよび標準ライブラリを通じてプラットフォームに依存します。 1)bytecodeとjvmを使用して、オペレーティングシステムの違いを抽象化します。 2)標準のライブラリは、パスクラス処理ファイルパス、CHARSETクラス処理文字エンコードなど、クロスプラットフォームAPIを提供します。 3)最適化とデバッグのために、実際のプロジェクトで構成ファイルとマルチプラットフォームテストを使用します。

java'splatformentencentenhancesmicroservicesecturectureby byofferingdeploymentflexability、一貫性、スケーラビリティ、およびポート可能性。1)展開の展開の展開は、AllosmicRoserviThajvm.2)deploymentflexibility lowsmicroserviceSjvm.2)一貫性のあるAcrossServicessimplisimpligiessdevelisementand

Graalvmは、Javaのプラットフォームの独立性を3つの方法で強化します。1。言語間の相互運用性、Javaが他の言語とシームレスに相互運用できるようにします。 2。独立したランタイム環境、graalvmnativeimageを介してJavaプログラムをローカル実行可能ファイルにコンパイルします。 3.パフォーマンスの最適化、Graalコンパイラは、Javaプログラムのパフォーマンスと一貫性を改善するための効率的なマシンコードを生成します。

aeffectivelytestjavaapplicationsforformcompativity、followthesesteps:1)setupautomatedacrossmultipleplatformsusingsingcitoolslikejenkinsorgithubactions.2)divivisonmanualtingonrealhardwaretocatissusuessususus.3)

Javaコンパイラは、ソースコードをプラットフォームに依存しないバイトコードに変換することにより、Javaのプラットフォームの独立性を実現し、JVMがインストールされた任意のオペレーティングシステムでJavaプログラムを実行できるようにします。

bytecodeachievesplatformedentencedexedectedbyavirtualMachine(VM)、forexApplev.forexample、javabytecodecanrunrunrunnonydevicewithajvm、writeonce、runany "ferfuctionality.whilebytecodeOffersenhの可能性を承認します

Javaは100%のプラットフォームの独立性を達成することはできませんが、そのプラットフォームの独立性はJVMとBytecodeを通じて実装され、コードが異なるプラットフォームで実行されるようにします。具体的な実装には、次のものが含まれます。1。bytecodeへのコンパイル。 2。JVMの解釈と実行。 3。標準ライブラリの一貫性。ただし、JVMの実装の違い、オペレーティングシステムとハードウェアの違い、およびサードパーティライブラリの互換性は、プラットフォームの独立性に影響を与える可能性があります。

Javaは、「Write onse、Averywhere」を通じてプラットフォームの独立性を実現し、コードの保守性を向上させます。 2。メンテナンスコストが低いため、1つの変更のみが必要です。 3.チームのコラボレーション効率が高く、知識共有に便利です。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

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

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

ホットトピック









