组件扫描(component scanning):
Spring能够从指定的classpath下自动扫描,侦测和实例化具有特定注解的bean。
Spring提供了一下几个注解来标注需要被扫描到的bean:
以前实例化一个bean要在配置文件中写bean标签,like this:
<bean id="a" class="lesson01.beans.A" scope="singleton">
<property name="name" value="张三"></property>
</bean>
有了这个扫描机制之后呢,只需要在类上加个注解,Spring容器一扫描到这个注解,就会自动实例化这个类:
@Component
public class A {
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
对于扫描到的组件,Spring有默认的命名策略:使用非限定类名,第一个字母小写。
也可以在注解中通过value属性值标识组建的名称。不使用value属性标识Bean的名称,默认以类名小写命名。
当在组件类上使用了特定的注解之后, 还需要在 Spring 的配置文件中配置以下项:
需要引入context命名空间
<!-- 组件扫描 -->
<context:component-scan base-package="lesson02.anno"</context:component-scan>
base-package 属性指定一个需要扫描的基类包,Spring 容器将会扫描这个基类包里及其子包中的所有类,当需要扫描多个包时, 可以使用逗号分隔。
测试类:
// 创建容器
ApplicationContext context = new ClassPathXmlApplicationContext("classpath:lesson02/anno/spring.xml");
A a = (A)context.getBean("theA");
System.out.println(a);
结果是能够获取到实例。
使用@Component注解的value属性命名:@Component(“实例名”)
在getBean时就要按照自定义的实例名去取了,不多BB。
Autowired自动装配
Spring提供了@Autowired注解来指定自动装配,@Autowired可以修饰setter方法、普通方法、实例变量和构造器等。当使用@Autowired标注setter方法时,默认采用byType自动装配策略。
示范:
import java.util.List;
import java.util.Map;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;
@Repository
public class MyDAO {
/*
* 在配置文件中定义好这个JdbcTemplate,在这里加上
* Autowired注解,容器会自动把Bean装配到这里,因为
* Spring类的自动装配机制默认是以类型装配。
*
* 注意:Autowired不支持静态变量的注入
*/
@Autowired
private JdbcTemplate template;
/**
* 执行查询
* @param sql
* @return
*/
public List<Map<String, Object>> query(String sql){
return template.queryForList(sql);
}
}
配置文件中定义好 template 实例即可。
Spring 还支持 @Resource 和 @Inject 注解,这两个注解和 @Autowired 注解的功用类似。@Resource 注解要求提供一个 Bean 名称的属性,若该属性为空,则根据类型装配。
定义方式:
但是呢大部分项目都是用@Autowired进行装配的,@Resource还是比较少见,建议使用 @Autowired 注解。
@Resource是JDK自带的注解,耦合度低
@Inject 和 @Autowired 注解一样也是按类型匹配注入的 Bean, 但没有 reqired 属性
过滤扫描
这个功能需要用以下两个子标签实现:
- context:include-filter : 表示要包含的类
- context:exclude-filter:表示要排除在外的目标类
<context:include-filter type="annotation" expression="lesson02.anno.mvc.CreateIt"/>
<!--CreateIt是一个自定义的注解,这行代码的意思呢就是告诉Spring容器,把使用了这个注解的类实例化。-->
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<!--排除使用了org.springframework.stereotype.Controller这个注解的类,使用了这个注解的类不会被Spring容器实例化。-->
type属性以及expression说明:
————————————————
版权声明:本文为CSDN博主「黄盖苦肉六张闪」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_36311372/article/details/78525509