目录
一、什么是注解?
1)注解是代码的一种特殊标记,格式:@注解名称(属性名称 = 属性值,属性名称 = 属性值,...)
2)使用注解,注解可以作用在类上面、方法上面、属性上面
3)使用注解的目的:简化XML配置,更加简洁
二、Spring针对Bean管理中创建对象提供了四种注解
放在类上面
1)@Component
2)@Service
3)@Controller
4)@Repository
注意:上面四种注解的功能是完全一样的,都可以用来创建bean实例,在开发中根据类的作用来选择即可。
三、基于注解方式实现对象创建
1、引入依赖
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>5.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>5.3.16</version>
</dependency>
</dependencies>
2、开启组件扫描
<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">
<!--开启组件扫描
如果扫描多个包,多个包之间只用逗号个号
-->
<context:component-scan base-package="bean"></context:component-scan>
</beans>
3、创建类,在类上面添加创建对象注解
代码如下例:
@Component(value = "user")
public class User {
@Value(value = "小h")
private String name;
@Value(value = "20")
private Integer age;
@Autowired
@Qualifier(value = "school")
private School school;
@Component
public class School {
public void add(){
System.out.println("school add 方法。。。。");
}
}
其中value的属性值可以省略不写(默认是类名称,首字母小写)
四、基于注解方式实现属性注入(四种注解)
1)@Autowired:根据属性的类型进行自动装配
2)@Qualifier:根据名称进行注入,要和上面的@Autowired一起搭配使用
3)@Resource:可以根据类型注入,也可以根据名称注入
4)@Value:用于注入普通类型属性
具体使用如下例:
public class User {
@Value(value = "小h")
private String name;
@Value(value = "20")
private Integer age;
@Autowired//根据属性类型
@Qualifier(value = "school")//根据名称
private School school;
public void add() {
System.out.println("user add 方法。。。。。");
}
五、完全注解开发
完全注解开发就是创建一个配置类用来代替XML配置文件
如下,创建一个配置类:
@Configuration //作为配置类的一个注解,代替XML配置文件
@ComponentScan(basePackages = {"bean"}) //开启注解扫描,里面的包是一个String数组类型,可以有多个
public class SpringConfig {
}
六、测试结果
@Test
public void test(){
AnnotationConfigApplicationContext context =
new AnnotationConfigApplicationContext(SpringConfig.class);
User user = context.getBean("user", User.class);
System.out.println(user.getName());
System.out.println(user.getSchool());
user.getSchool().add();
}
总结
不得不说,使用完全注解开发比XML配置文件真的要简洁很多!
欢迎指正和交流哦!