@EnableAutoConfiguration 代码详解
时间: 2023-03-30 19:03:28 浏览: 53
@EnableAutoConfiguration 注解是 Spring Boot 的注解之一。
当你在类路径中添加了一个或多个启动器(starter)依赖时,它会自动地添加和配置一些常用的库,以便你能够快速地开发应用。
这个注解会扫描你的应用程序,搜索所有的 @Configuration 类,并将它们应用到你的应用程序上下文。
此外,还会自动配置你的应用,以使用任何你在类路径中找到的库。比如,如果你在类路径中添加了 spring-webmvc 库,那么它会自动地配置 DispatcherServlet 和 Spring MVC。
使用这个注解可以让你的应用程序快速地启动和运行,并且能够自动地适应你的应用程序中所用到的库。
相关问题
@Autowired注解详解
@Autowired注解用于自动装配Spring容器中的Bean。当标注在构造函数上时,会将符合类型的Bean自动注入到构造函数中作为参数。如果属性是一个接口类型,它会根据类型找到对应的实现类进行注入。如果有多个实现类,可以结合@Qualifier注解指定具体要注入的实现类的名称。
需要注意的是,在BeanPostProcessor类和BeanFactoryPostProcessor类中无法使用@Autowired注解。因为@Autowired注解的收集工作是由BeanPostProcessor类完成的,而BeanFactoryPostProcessor类的调用时机先于BeanPostProcessor类,所以无法使用@Autowired注解在这两个类中。
另外,如果想禁用某些特定构造函数的自动装配,可以使用注释将其注释掉。比如在代码中使用/* */将构造函数注释掉,可以阻止@Autowired注解的自动注入。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *3* [@Autowired注解详解——超详细易懂](https://blog.csdn.net/weixin_45755816/article/details/118654961)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* [@Autowired注解详解](https://blog.csdn.net/qq1309664161/article/details/119293360)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
@RequiredArgsConstructor注解详解
`@RequiredArgsConstructor` 是一个 Lombok 注解,它可以帮助我们自动生成一个包含所有 `@NonNull` 注解的成员变量的构造函数。同时,如果类中还有其他非 `@NonNull` 注解的成员变量,也会被包含在构造函数中。这个注解可以帮助我们避免手动编写构造函数的繁琐过程,提高代码的可读性和可维护性。
下面是一个使用 `@RequiredArgsConstructor` 注解的例子:
```java
import lombok.RequiredArgsConstructor;
import lombok.NonNull;
@RequiredArgsConstructor
public class Person {
private final String name;
@NonNull
private String gender;
private int age;
}
```
在上面的例子中,我们使用了 `@RequiredArgsConstructor` 注解来自动生成一个包含 `name` 和 `gender` 两个成员变量的构造函数。其中,`gender` 成员变量被标记为 `@NonNull`,所以它会被包含在构造函数中。而 `age` 成员变量没有被标记为 `@NonNull`,所以它不会被包含在构造函数中。
生成的构造函数的代码如下:
```java
public Person(String name, String gender) {
this.name = name;
this.gender = gender;
}
```
需要注意的是,`@RequiredArgsConstructor` 注解只会生成包含标记为 `@NonNull` 的成员变量的构造函数,如果类中没有任何标记为 `@NonNull` 的成员变量,那么它就不会生成任何构造函数。