在Spring4之后,要使用注解开发,必须保证aop的包导入了

使用注解需要导入context,增加注解的支持
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        https://www.springframework.org/schema/context/spring-context.xsd">

    <context:annotation-config/>

</beans>
1.bean
2.属性如何注入
@Component
public class User {
    
    public String name ;

//    相当于<property name="name" value="Violet"/>
    @Value("Violet")
    public void setName(String name){
        this.name = name;
    }
3.衍生的注解

@Component有几个衍生注解,我们在web开发中,会按照mvc三层架构分层

  • dao 【@Repository】
  • service 【@Service】
  • controller 【@Controller】

这个四个注解功能一样,只是用在不同的类中,注册Spring,装配bean

4.自动装配

  • @Autowired : 自动装配通过类型、名字
    • 如果Autowired不能唯一自动装配上属性,则通过@Qualifier(value=”xxx”)
  • @Nullable 字段标记了这个注解,说明这个字段可以为null
  • @Resource :自动装配通过名字、类型

5.作用域

@Component
@Scope("prototype")     //原型,不是单例
public class User {

    public String name ;

//    相当于<property name="name" value="Violet"/>
    @Value("Violet")
    public void setName(String name){
        this.name = name;
    }

6.小结

xml与注解:

  • xml更加万能,适用于任何场合,维护简单方便
  • 注解不是自己的类使用不了,维护相对复杂

xml与注解最佳实践:

  • xml用来管理bean;
  • 注解只负责完成属性的注入;
  • 我们在使用的过程中,只需要注意一个问题:必须要注解生效,就需要开启注解的支持
<!--指定要扫描的包,这个包下的注解就会生效-->
<context:component-scan base-package="com.mine"/>
<!--注解驱动-->
<context:annotation-config/>