目录
首先使用注解必须要导入依赖
在配置文件当中,还得要引入一个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联用