Spring-注解的使用

目录

@Autowirded

@Component

@Component三个衍生注解

@Scope


首先使用注解必须要导入依赖

在配置文件当中,还得要引入一个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:aop="http://www.springframework.org/schema/aop"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xmlns:p="http://www.springframework.org/schema/p"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/aop
       http://www.springframework.org/schema/aop/spring-aop.xsd
       http://www.springframework.org/schema/mvc
       http://www.springframework.org/schema/mvc/spring-mvc.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context.xsd">

@Autowirded

@Autowired注入首先根据byType注入,当类型大于1时在根据byName注入。

@Autowired注入是除set注入和构造器注入的第三种注入bean的方式

使用前,用普通的set注入bean

自动注入方式

@Data
public class User {
//方法1,在字段上注入
 //   @Autowired
    private Cat cat;
 //   @Autowired
    private Dog dog;
    private String str;

//方法2,在set方法上注入
    @Autowired
    public void setCat(Cat cat) {
        this.cat = cat;
    }
   @Autowired
    public void setDog(Dog dog) {
        this.dog = dog;
    }

}

 一定要加这行代码!!

<context:annotation-config/>

//Autowired required属性默认为true,如果设置为false,说明这个对象可以为null,否则不允许为空

@Autowired(required = false)

还可以在字段上加@Nullable注解,同样的效果

 但是如果你配置很多的bean,面对复杂的bean时

   <bean id="cat" class="com.wjc.pojo.Cat"/>
    <bean id="cat222" class="com.wjc.pojo.Cat"/>
    <bean id="dog222" class="com.wjc.pojo.Dog"/>
    <bean id="dog" class="com.wjc.pojo.Dog"/>
    <bean id="user" class="com.wjc.pojo.User"/>

自动注入会变得很困难,可以去使用

@Qualifier(value = "cat222")来找对应类型bean的id
    @Autowired
    @Qualifier(value = "cat222")
    public void setCat(Cat cat) {
        this.cat = cat;
    }

    @Autowired
    @Qualifier(value = "cat222")        注解还能被@Resource注解替代

  @Resource(name = "cat222")
    public void setCat(Cat cat) {
        this.cat = cat;
    }

@Component

扫描组件注解

要使用该注解必须在配置文件里面配置


<!--指定要扫描的包,这个包下的注解就会生效-->
   <context:component-scan base-package="com.wjc.pojo"/>

我们之前如果写了个类,就需要去配置文件里面配置bean

<bean id="user" class="com.wjc.pojo.User"/>

使用@Component注解就替代了上面的代码 ,id默认是类名首字母小写,也可以用value来给id赋值

@Component(value = "user22")
public class User {

    public  String name="小明";

}

测试的时候也可以拿到值

   @Test
    public  void test1(){
        ApplicationContext app=new ClassPathXmlApplicationContext("applicationContext.xml");
        User user = app.getBean("user222", User.class);
        System.out.println(user.name);

    }

那我们现在如何去给里面的属性赋值呢?

@Value注解赋值

@Value("小明")
    public  String name;

@Component三个衍生注解

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

  • @Controller:web层

  • @Service:service层

  • @Repository:dao层

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

@Scope

  • singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂 ,所有的对象都会销毁。

  • prototype:多例模式。关闭工厂 ,所有的对象不会销毁。内部的垃圾回收机制会回收

@Controller("user")
@Scope("prototype")
public class User {
   @Value("小明")
   public String name;
}

小结

XML与注解比较

  • XML可以适用任何场景 ,结构清晰,维护方便

  • 注解不是自己提供的类使用不了,开发简单方便

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

  • xml管理Bean

  • 注解完成属性注入

  • 使用注解必须记得要开始注解扫描,使注解生效

对于@Autowired和@Component,@Autowired织入(Spring上下文已有实例(已注入IOC),@Autowired只是取一下)@Autowired说“请给我一个该类的实例,例如,我之前用@Bean注释创建的一个实例进入IOC了”。而@Component把普通pojo实例化到spring容器中,相当于配置文件中的<bean id="" class=""/>

虽然有了@Autowired,但是我们还是要写一堆bean的配置文件,相当麻烦,而@Component就是告诉spring,我是pojo类,把我注册到容器中吧,spring会自动提取相关信息。那么我们就不用写麻烦的xml配置文件了。

实际项目一般是@Component配合@Autowired联用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JagTom

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值