インタビュアー: @Configuration と @Component の違い
昨日、友人が、アノテーション @Configuration
と @ について質問されたと私に報告してくれました。インタビュー. コンポーネント
の違い。
一文でまとめると、@Configuration
内の @Bean
アノテーションを持つすべてのメソッドは動的にプロキシされるため、このメソッドを呼び出すと次の結果が返されます。同じインスタンス。
理解: @Configuration
クラスの @Bean アノテーション付きメソッドを呼び出すと、同じ例が返されますが、@Component
クラスの @ メソッドBean
アノテーションが付けられたは、新しいインスタンスを返します。
“
注: 上記の呼び出しは Spring コンテナーから取得されたものではありません! 以下の下部の例 1 と例 2
を参照してください。実装の詳細を確認してください。
@構成アノテーション
@Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) @Documented @Component public @interface Configuration { String value() default ""; }
定義から、@構成
アノテーションは本質的に @ Component
であるため、<context:component-scan/>
または @ComponentScan
は、@Configuration
のアノテーションが付けられたクラスを処理できます。
@構成
マークされたクラスは次の要件を満たす必要があります:
配置类必须以类的形式提供(不能是工厂方法返回的实例),允许通过生成子类在运行时增强(cglib 动态代理)。 配置类不能是final 类(没法动态代理)。 配置注解通常为了通过 @Bean
注解生成 Spring 容器管理的类,配置类必须是非本地的(即不能在方法中声明,不能是 private)。 任何嵌套配置类都必须声明为static。 @Bean
方法可能不会反过来创建进一步的配置类(也就是返回的 bean 如果带有@Configuration
,也不会被特殊处理,只会作为普通的 bean)。
@Bean 注解方法执行策略
先给一个简单的示例代码:
@Configuration public class MyBeanConfig { @Bean public Country country(){ return new Country(); } @Bean public UserInfo userInfo(){ return new UserInfo(country()); } }
相信大多数人第一次看到上面 userInfo()
中调用 country()
时,会认为这里的 Country和上面 @Bean
方法返回的 Country 可能不是同一个对象,因此可能会通过下面的方式来替代这种方式:
@Autowired
private Country country;
实际上不需要这么做(后面会给出需要这样做的场景),直接调用country()
方法返回的是同一个实例。
@Component 注解
@Component
注解并没有通过 cglib 来代理@Bean
方法的调用,因此像下面这样配置时,就是两个不同的 country
。
@Component public class MyBeanConfig { @Bean public Country country(){ return new Country(); } @Bean public UserInfo userInfo(){ return new UserInfo(country()); } }
有些特殊情况下,我们不希望 MyBeanConfig
被代理(代理后会变成WebMvcConfig$$EnhancerBySpringCGLIB$$8bef3235293
)时,就得用 @Component
,这种情况下,上面的写法就需要改成下面这样:
@Component public class MyBeanConfig { @Autowired private Country country; @Bean public Country country(){ return new Country(); } @Bean public UserInfo userInfo(){ return new UserInfo(country); } }
这种方式可以保证使用的同一个 Country 实例。
示例 1:调用@Configuration类中的@Bean注解的方法,返回的是同一个示例
第一个bean类
package com.xl.test.logtest.utils; public class Child { private String name = "the child"; public String getName() { return name; } public void setName(String name) { this.name = name; } }
第二个bean类
package com.xl.test.logtest.utils; public class Woman { private String name = "the woman"; private Child child; public String getName() { return name; } public void setName(String name) { this.name = name; } public Child getChild() { return child; } public void setChild(Child child) { this.child = child; } }
@Configuration
类
package com.xl.test.logtest.utils; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.stereotype.Component; @Configuration //@Component public class Human { @Bean public Woman getWomanBean() { Woman woman = new Woman(); woman.setChild(getChildBean()); // 直接调用@Bean注解的方法方法getChildBean() return woman; } @Bean public Child getChildBean() { return new Child(); } }
测试类 I
本测试类为一个配置类,这样启动项目是就可以看到测试效果的,更加快捷;也可以使用其他方式测试见下面的测试类 II
package com.xl.test.logtest.utils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Configuration; @Configuration public class Man { @Autowired public Man(Woman wn, Child child) { System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>"); System.out.println(wn.getChild() == child ? "是同一个对象":"不是同一个对象"); } }
启动项目,查看输出结果:

测试类 II
package com.xl.test.logtest.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; import com.xl.test.logtest.utils.Child; import com.xl.test.logtest.utils.Woman; @RestController public class LogTestController { @Autowired Woman woman ; @Autowired Child child; @GetMapping("/log") public String log() { return woman.getChild() == child ? "是同一个对象":"不是同一个对象"; } }
浏览器访问项目,查看结果;输入localhost:8080/log

示例 2 :调用@Component类中的@Bean注解的方法,返回的是一个新的实例。
测试代码,只需要将@Configuration
改为@Component
即可!其他的均不变
package com.xl.test.logtest.utils; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.stereotype.Component; //@Configuration @Component public class Human { @Bean public Woman getWomanBean() { Woman woman = new Woman(); woman.setChild(getChildBean()); // 直接调用@Bean注解的方法方法getChildBean() return woman; } @Bean public Child getChildBean() { return new Child(); } }
测试 :

控制台和浏览器展示,均符合预期!
最后,如果你也需要修改简历,需要模拟面试的。
以上がインタビュアー: @Configuration と @Component の違いの詳細内容です。詳細については、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)

ホットトピック











@Configuration クラスで @Bean アノテーション付きメソッドを呼び出すと同じ例が返され、@Component クラスで @Bean アノテーション付きメソッドを呼び出すと新しいインスタンスが返されます。

1. コンポーネントの基本的な動的導入: 単純な動的導入とは、フロントエンドがどのコンポーネントを導入するかを認識し、複数のコンポーネントを親コンポーネントに導入しますが、レンダリングはしません。特定の条件が満たされた後、特定の時点でレンダリングされます。場所、指定されたコンポーネント。 import{reactive,ref,shallowReactive,onActivated,defineAsyncComponent,}from'vue';constcustomModal=defineAsyncComponent(()=>import('./modal/CustomM

Vue.js は、コンポーネントをカスタマイズするための多くの API を提供する人気のあるフロントエンド フレームワークです。この記事では、コンポーネントのカスタマイズのスキルを習得するのに役立つ、Vue の mixin、extend、コンポーネント、およびその他の API を紹介します。 Mixin Mixin は、Vue でコンポーネント コードを再利用する方法です。これにより、すでに記述されたコードを別のコンポーネントに再利用できるため、重複したコードを記述する必要性が減ります。たとえば、ミックスインを使用すると、複数のグループを結合できます。

1. 簡単な紹介: @Configuration アノテーションはクラスにアノテーションを付けることができます クラスに @Configuration アノテーションが付けられている場合、Spring は @Configuration アノテーションが付けられたクラスを自動的にスキャンし、IOC コンテナに登録し、Bean オブジェクトにインスタンス化します。 @Configuration アノテーションが付与されたクラスに @Bean アノテーションが付与されたクラスオブジェクトを作成するメソッドが含まれている場合、Spring は @Bean アノテーションが付与されたメソッドも自動的に実行し、対応する Bean 定義情報を IOC コンテナに登録します。それをインスタンス化します。 2. アノテーションの説明 @Configuration アノテーションは Spring 3.0 バージョンから追加されたツールです。

Reactにおけるコンポーネントとは中国語で「部品」を意味し、独立した機能を持ったUIコンポーネントをカプセル化したもので、表示するコンテンツを複数の独立した部分に分割し、その一つ一つをコンポーネントと呼びます。コンポーネントには 2 つの重要なものがあります。1 つはプロパティ、もう 1 つは状態です。コンポーネントのプロパティは親コンポーネントによって与えられ、子コンポーネントに対する親コンポーネントの要件を保存します。プロパティはコンポーネント内でアクセスできますが、変更できません。コンポーネントの状態は定義されて使用されます。コンポーネント自体による保存 コンポーネントの現在の状態 コンポーネントの状態は変更可能です。

@Configuration 注意点 1 構成クラス (@Configuration の下のこのクラス) は、実際にはファクトリと同等です。@Bean アノテーションでマークされたメソッドは、ファクトリ メソッドと同等です。次の例を考えてください: @Configuration // 注意点 1:設定クラスは実際にはファクトリと同等であり、@Bean アノテーションでマークされたメソッドはファクトリ メソッド staticclassMyConfig{@BeanpublicBean1bean1(){System.out.println("bean1()");returnnewBean1();} と同等です。将来 Bean1 のインスタンスを生成するため

React.component エラーの解決策: 1. 対応する反応ファイルを開き、「class Counter extends Component {static propTypes = {...」ステートメントを探し、等号をコロンに変更します。 2. 「{」を変更します。 "presets": ["react", "es2015", "stage-0"]}" で十分です。

@Configuration アノテーションは Spring で XML 設定ファイルを使用する効果を実現できます。@Bean は XML 設定ファイルに相当します。Spring プロジェクトでは、hiro などのサードパーティ フレームワークを統合し、spring.xml 設定で設定します。ファイル、例: / css/**=anon/js/**=anon/validatecode.jsp*=anon/images/**=anon/login.jsp=anon/service/**=anon/**= authc は springboot の hiro と統合します:@Configurationpublic
