spring学习7-注解开发

使用注解开发

说明

在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
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

</beans>

将bean添加到容器中

我们之前都是使用 bean 的标签进行bean注入,但是实际开发中,我们一般都会使用注解!
配置扫描哪些包下的注解

   <!--指定注解扫描包-->
   <context:component-scan base-package="com.cong.pojo"/>

在指定包下编写类,使用注解@Value注入属性

   @Component("user")// 相当于配置文件中 <bean id="user" class="当前注解的类"/>
   public class User {
       @Value("cong")// 相当于配置文件中 <property name="name" value="cong"/>
       private String name;
       
       @Override
       public String toString() {
           return "User{" +
                   "name='" + name + '\'' +
                   '}';
       }
   }

测试

@Test
public void test1(){
   ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
   User user = (User) context.getBean("user");
   System.out.println(user.toString());
}

扩展

@Value也可以作用在方法上

@Component后面的value可以不写,默认是类的小写

@Component
public class User {
    private String name;
    
    @Value("cong")
    public void setName(String name) {
        this.name = name;
    }
    
    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                '}';
    }
}

衍生注解

我们这些注解,就是替代了在配置文件当中配置步骤而已!更加的方便快捷!

@Component三个衍生注解

为了更好的进行分层,Spring可以使用其它三个注解,功能一样,目前使用哪一个功能都一样。

  • @Controller:web层
  • @Service:service层
  • @Repository:dao层

写上这些注解,就相当于将这个类交给Spring管理装配了!

自动装配注解

主要有4个注解,之前讲过了

@Autowired

自动按照类型注入

如果存在多个同类型的bean,会自动装配类名小写的bean

@Qualifier

不能单独使用,配合@Autowired,根据id装配对应的bean

@Resource

  • @Resource如有指定的name属性,先按该属性进行byName方式查找装配;
  • 其次再进行默认的byName方式进行装配;
  • 如果以上都不成功,则按byType的方式自动装配。
  • 都不成功,则报异常。

@Nullable

字段标记了这个,则可以为null值

作用域

@scope

@scope

  • singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂 ,所有的对象都会销毁。
  • prototype:多例模式。关闭工厂 ,所有的对象不会销毁。内部的垃圾回收机制会回收
@Component
@Scope("singleton")
public class User {
    @Value("cong")
    private String name;
    @PostConstruct//指定初始化方法
    public void init(){
        System.out.println("对象初始化了...");
    }
    @PreDestroy//指定销毁方法
    public void destroy(){
        System.out.println("对象销毁了...");
    }
    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                '}';
    }
}

再次运行,结果

对象初始化了...
User{name='cong'}
对象销毁了...

小结

XML与注解比较

  • XML可以适用任何场景 ,结构清晰,维护方便
  • 注解不是自己提供的类使用不了,开发简单方便

xml与注解整合开发 :推荐最佳实践

  • xml管理Bean
  • 注解完成属性注入
  • 使用过程中, 可以不用扫描,扫描是为了类上的注解
<context:annotation-config/>  

作用:

  • 进行注解驱动注册,从而使注解生效
  • 用于激活那些已经在spring容器里注册过的bean上面的注解,也就是显示的向Spring注册
  • 如果不扫描包,就需要手动配置bean
  • 如果不加注解驱动,则注入的值为null!

猜你喜欢

转载自www.cnblogs.com/ccoonngg/p/12026757.html