ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、视频、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
~~~ <!-- <context:component-scan> 元素还会自动注册 AutowiredAnnotationBeanPostProcessor 实例, 该实例可以自动装配具有 @Autowired 和 @Resource 、@Inject注解的属性. @Autowired 自动装配具有兼容类型的单个Bean属性 1.构造器, 普通字段(即使是非 public), 一切具有参数的方法(如set方法)都可以应用@Authwired 注解 2.默认情况下, 所有使用 @Authwired 注解的属性都需要被设置. 当 Spring 找不到匹配的 Bean 装配属性时, 会抛出异常, 若某一属性允许不被设置, 可以设置 @Authwired 注解的 required 属性为 false (@Autowired(required=false)//required=false表示IOC容器中如果没有匹配的对象可以注入的时候,那么就是一个null,并不会报异常) 3.默认情况下, 当 IOC 容器里存在多个类型兼容的 Bean 时, 通过类型的自动装配将无法工作. 此时可以在 @Qualifier 注解里提供 Bean 的名称. Spring 允许对方法的入参标注 @Qualifiter 已指定注入 Bean 的名称 (* 在自动装配的时候,有可能IOC容器中,有多个类型兼容的bean * 构造方法把@Qualifier注解写在方法的入参public UserController(@Qualifier("userService2") UserService us){ this.us=us;set方法写在上面就行) ~~~ ![](https://box.kancloud.cn/b62611d3309642c2a3eae815ac1ecbe8_903x354.png) @Qualifier("userService2")也可以写在属性上 @Resource(name="userService2") ~~~ 了解: @Authwired 注解也可以应用在数组类型的属性上, 此时 Spring 将会把所有匹配的 Bean 进行自动装配. @Authwired 注解也可以应用在集合属性上, 此时 Spring 读取该集合的类型信息, 然后自动装配所有与之兼容的 Bean. @Authwired 注解用在 java.util.Map 上时, 若该 Map 的键值为 String, 那么 Spring 将自动装配与之 Map 值类型兼容的 Bean, 此时 Bean 的名称作为键值 Spring 还支持 @Resource 和 @Inject 注解,这两个注解和 @Autowired 注解的功用类似 @Resource 注解要求提供一个 Bean 名称的属性,若该属性为空,则自动采用标注处的变量或方法名作为 Bean 的名称 @Inject 和 @Autowired 注解一样也是按类型匹配注入的 Bean, 但没有 reqired 属性 建议使用 @Autowired 注解 --> ~~~