例
interface IA
{
public void someFunction();
}
@Resource(name="b")
class B implements IA
{
public void someFunction()
{
//busy code block
}
public void someBfunc()
{
//doing b things
}
}
@Resource(name="c")
class C implements IA
{
public void someFunction()
{
//busy code block
}
public void someCfunc()
{
//doing C things
}
}
class MyRunner
{
@Autowire
@Qualifier("b")
IA worker;
worker.someFunction();
}
誰かが私にこれを説明できますか。
@Qualifier
または@Resource
が必要ですか?スプリングはどのポリモーフィックタイプを使用するかをどのように知っていますか。
インターフェースの実装が1つだけであり、その実装にSpringのコンポーネントスキャンが有効になっている@Component
注釈が付けられている限り、Springフレームワークは(インターフェース、実装)のペアを見つけることができます。コンポーネントのスキャンが有効になっていない場合は、application-config.xml(または同等のスプリング構成ファイル)でBeanを明示的に定義する必要があります。
@Qualifierまたは@Resourceが必要ですか?
複数の実装を作成したら、それぞれを修飾する必要があり、自動配線中に、@Qualifier
注釈とともに正しい実装を注入するために@Autowired
注釈を使用する必要があります。 @Resource(J2EEセマンティクス)を使用している場合、このアノテーションのname
属性を使用してBean名を指定する必要があります。
実装されたクラスではなく、インターフェイスを自動配線するのはなぜですか?
まず、一般的なインターフェイスへのコーディングは常に良い習慣です。第二に、春の場合、実行時に任意の実装を挿入できます。典型的な使用例は、テスト段階でモック実装を注入することです。
interface IA
{
public void someFunction();
}
class B implements IA
{
public void someFunction()
{
//busy code block
}
public void someBfunc()
{
//doing b things
}
}
class C implements IA
{
public void someFunction()
{
//busy code block
}
public void someCfunc()
{
//doing C things
}
}
class MyRunner
{
@Autowire
@Qualifier("b")
IA worker;
....
worker.someFunction();
}
Beanの構成は次のようになります。
<bean id="b" class="B" />
<bean id="c" class="C" />
<bean id="runner" class="MyRunner" />
または、これらが存在するパッケージでコンポーネントスキャンを有効にした場合は、次のように各クラスを@Component
で修飾する必要があります。
interface IA
{
public void someFunction();
}
@Component(value="b")
class B implements IA
{
public void someFunction()
{
//busy code block
}
public void someBfunc()
{
//doing b things
}
}
@Component(value="c")
class C implements IA
{
public void someFunction()
{
//busy code block
}
public void someCfunc()
{
//doing C things
}
}
@Component
class MyRunner
{
@Autowire
@Qualifier("b")
IA worker;
....
worker.someFunction();
}
次に、worker
のMyRunner
に、タイプB
のインスタンスが注入されます。
また、 Cglib2AopProxy Unproxy method などのログで警告が発生する場合があります。そして、これに関する他の多くの理由をここで説明します なぜサービスとdaoレイヤーに常に単一の実装インターフェースがあるのですか?