Spring基于注解的方式配置bean的实例

  前边我们讲过了基于配置文件创建bean实例的另外一种方式:即使用FacctoryBean的实现类来创建配置文件中bean的实例。下边我们讲一讲使用非常频繁的基于注解的方式来创建bean的实例。

  1.注解配置bean的实例

  ① Spring框架可以从classpath(src)下自动扫描、侦测和实例化带有特定注解的组件(类)。

  ② 特定注解一般有@Component,基本注解,标识了一个受Spring管理的组件;@Repository,一般用于标识持久层的组件;@Service,一般用于标识业务层的组件;@Controller,一般用于标识表现层的组件。需要注意的是Spring框架时无法根据注解的内容区分识别不同的层级,我们只是将不同的注解标识在不同的层级上以利于观察。

  ③ Spring在扫描到这些带有特定注解的类之后,会给这些类创建对应的实例并且命名,相当于配置文件中的id值。Spring采用默认的命名策略:

  类名首字母小写,代表这个类实例的id名称。

  也可以手动的在注解之后添加一个value属性执行当前这个类的实例的名称,如@Component(value="liucc")

  ④ Spring可以扫描这些组件,但是还必须在SpringIOC容器中进行配置,指定Spring扫描的具体的包及其子包下的类。

  <context:component-scan base-package="com.liucc">  注意包的层级(包之间也是有层级之分的)

  当有多个同等级的包需要被扫描时,可用逗号将其分割即可。

  ⑤ 在扫描的过程中,如果我们希望只扫描某个特定的类,则需要用到属性resource-pattern来指定特定的.class类

  <context:component-san base-package="com.liucc.pojo" resource-pattern="autowired/*.class"  >.

  ⑥ 我们还可以使用<context:component-san/>的子标签<context:include-filter>和<context:exclude-filter>来指定只扫描的类或者排除扫描的类。

  具体的方式可以使用type先指定包含或者排除方式,有annotation和assignble两种。前者指定扫描类的注解类型,后者指明扫描类的全类名。

  需要注意的是,如果我们使用<context:include-filter>,那么还必须在<context:component-san>节点上将use-default-filter置为false,否则无法起作用。(默认为true)

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值