[解決済み】SpringのApplicationContext.getBeanがダメだと言われる理由とは?
質問
Springの一般的な質問をしてみました。
Spring Beansのオートキャスト
を呼び出すと、複数の人から、Springの
ApplicationContext.getBean()
はできるだけ避けなければなりません。 それはなぜでしょうか?
Springで作成するように設定したBeanに、他にどのようにアクセスすればいいのでしょうか?
私は非ウェブアプリケーションでSpringを使用しており、共有の
ApplicationContext
オブジェクト
LiorHが説明したように
.
修正案
私は以下の答えを受け入れますが、以下はMartin Fowler氏による別の見解です。
Dependency InjectionとService Locatorのどちらが優れているかを議論しています。
(を呼び出すのと本質的に同じです)。
ApplicationContext.getBean()
).
その中で、ファウラー氏は、" サービスロケータでは、アプリケーションクラスはロケータへのメッセージによって明示的にそれ(サービス)を要求する。インジェクションでは、明示的な要求がなく、サービスがアプリケーションクラスの中に現れる-それゆえ、制御が逆転する。 制御の逆転は、フレームワークの一般的な機能ですが、それには代償が必要です。理解するのが難しく、デバッグするときに問題になりがちです。ですから、私は全体として、必要なとき以外は(制御の逆転を)避けることを好んでいます。これは、それが悪いということではなく、より単純な代替案よりもそれ自身を正当化する必要があると思うのです。 "。
どのように解決するのか?
他の質問のコメントにも書きましたが、Inversion of Controlの全体的な考え方は、以下の通りです。 どのクラスも、依存するオブジェクトをどのように取得するかは知りませんし、気にしません。 . これによって、ある依存関係の実装をどのようなものにするかをいつでも簡単に変更できるようになります。また、依存関係のモック実装を提供できるため、クラスのテストも容易になります。最後に、これによりクラスは よりシンプルに と、より中核的な責任に集中することができます。
呼び方
ApplicationContext.getBean()
は、Inversion of Controlではありません! 与えられたBean名に対して設定された実装を変更するのはまだ簡単ですが、クラスはその依存関係を提供するためにSpringに直接依存しており、他の方法でそれを取得することはできません。テストクラスで独自のモック実装を作成し、それを自分で渡すことはできません。これは基本的に、依存性注入コンテナとしてのSpringの目的を破っています。
言いたい放題。
MyClass myClass = applicationContext.getBean("myClass");
の場合は、代わりに、例えばメソッドを宣言する必要があります。
public void setMyClass(MyClass myClass) {
this.myClass = myClass;
}
そして、設定に
<bean id="myClass" class="MyClass">...</bean>
<bean id="myOtherClass" class="MyOtherClass">
<property name="myClass" ref="myClass"/>
</bean>
Springは自動的に
myClass
を
myOtherClass
.
このようにすべてを宣言して、その根底には次のようなものがある。
<bean id="myApplication" class="MyApplication">
<property name="myCentralClass" ref="myCentralClass"/>
<property name="myOtherCentralClass" ref="myOtherCentralClass"/>
</bean>
MyApplication
は最も中心的なクラスで、プログラム内の他のすべてのサービスに少なくとも間接的に依存しています。ブートストラップするとき、あなたの
main
メソッドを呼び出すと
applicationContext.getBean("myApplication")
を呼び出す必要はないはずです。
getBean()
を使用します。
関連
-
[解決済み] Application startメソッドで例外が発生する。JavaFx 11
-
[解決済み] この2回(1927年)を引き算すると、なぜおかしな結果になるのでしょうか?
-
[解決済み] なぜパスワードにはStringではなくchar[]が好まれるのですか?
-
[解決済み] serialVersionUIDとは何ですか、またなぜそれを使用する必要がありますか?
-
[解決済み] B "の印刷が "#"の印刷より劇的に遅いのはなぜですか?
-
[解決済み] リフレクションとは何か、なぜ有用なのか?
-
[解決済み] ランダムな文字列を使用するこのコードは、なぜ "hello world" と表示されるのですか?
-
[解決済み] なぜJavaにはtransientフィールドがあるのですか?
-
[解決済み] 静的変数が悪とされるのはなぜですか?
-
[解決済み】なぜJavaの+=, -=, *=, /=複合代入演算子はキャスティングを必要としないのですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] java.sql.SQLException: ORA-00933: SQL コマンドが正しく終了していません。
-
[解決済み] Java - JTextFieldが空かどうかを確認する
-
[解決済み] パラメータ[変数]の不正な修飾子;finalのみが許可される[closed]。
-
[解決済み] 環境変数JAVA_OPTSの使い方を教えてください。
-
[解決済み] Oracle DB : java.sql.SQLException: 閉じた接続
-
[解決済み] 要素 'beans' の宣言が見つかりません。
-
[解決済み] java.util.MissingFormatArgumentException: 形式指定子 '%s' がありません。
-
[解決済み] eclipseからTomcatに物理的に発行されるmyjspはどこにあるのでしょうか?
-
[解決済み] java swingアプリケーションでJCEがプロバイダBCを認証できない
-
[解決済み] .lengthが解決できない、またはフィールドでない