web-dev-qa-db-ja.com

Spring:実装されたクラスではなく、インターフェースを自動配線するのはなぜですか?

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が必要ですか?
  • 実装されたクラスではなく、インターフェイスを自動配線するのはなぜですか?
127
stackoverflow

スプリングはどのポリモーフィックタイプを使用するかをどのように知っていますか。

インターフェースの実装が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();
}

次に、workerMyRunnerに、タイプBのインスタンスが注入されます。

198
Vikdor

また、 Cglib2AopProxy Unproxy method などのログで警告が発生する場合があります。そして、これに関する他の多くの理由をここで説明します なぜサービスとdaoレイヤーに常に単一の実装インターフェースがあるのですか?

1
stokito