美文网首页
2.4基于注解的DI-第2章 IoC控制反转

2.4基于注解的DI-第2章 IoC控制反转

作者: 努力学习的lfk | 来源:发表于2021-08-19 09:27 被阅读0次

2.4基于注解的DI

di的实现有两种:
2.使用spring中的注解,完成属性赋值,叫做基于注解的di实现

使用注解的步骤:

1.加入maven的依赖:spring-context。在你加入spring-context的同时,间接加入spring-aop依赖。使用注解必须使用spring-aop依赖。

加载spring-context依赖.png spring-aop依赖.png

2.在类中加入spring的注解(多个不同功能的注解)

3.在spring的配置文件中,加入一个组件扫描器的标签,说明注解在你的项目的位置。

4.使用注解创建对,创建容器ApplicationContext

学习的注解:

前期准备:
新建模块.png 选择模板 修改pom文件.png 添加spring依赖.png
1.@Component

@Component:创建对象,等同于<bean>的功能

@Component(value = "myStudent")
等同于
<bean id=“myStudent” class=“com.bjpowernode.ba01.Student”>

属性:value就是对象的名字,也就是bean的id值
位置:在类的上面,表示创建该类的对象,名字叫value的值。

1)声明注解

//使用value 属性,指定对象名称
@Component(value = "myStudent")
//省略value 属性
@Component( "myStudent")

//不指定对象名称,由spring提供默认名称(类名的首字母小写)
@Component
注解的位置.png

2)创建组件扫描器

声明组件扫描器(component-scan),组件就是java对象
base-package:指定注解在你的项目中的包名,
component-scan工作方式:spring会扫描遍历base-package指定的包,把包和子包中的所有类遍历,找到类中的注解。按照注解的功能创建对象或给属性赋值。

基本语法:
<context:component-scan base-package="注解所在的包名"/>
创建配置文件目录.png 指定注解所在的包名.png

指定多个包的三种方式

  • 第一种方式:使用多次组件扫描器,指定不同包
如:
<context:component-scan base-package="com.bjpowernode.ba01"/>
<context:component-scan base-package="com.bjpowernode.ba02"/>
  • 第二种方式:使用分隔符(;或,)分隔多个包名
如:
<context:component-scan base-package="com.bjpowernode.ba01;com.bjpowernode.ba02"/>
  • 第三种方式:指定父包
如:
<context:component-scan base-package="com.bjpowernode"/>
//因为扫描器的特点是扫描包及子包中的类
//但是不要顶级包,包层数越多,扫描越慢
执行流程
1)读配置文件.png 2)读注解.png 3)创建对象.png

(因为ba01下只有一个类,且类里只有一个注解,故此时就扫描完了。对象此时就放进容器了)

2.@Respotory(用在持久层类的上面)

放在dao的实现类上面, 表示创建dao对象,dao对象就是访问数据库的。

3.@Service(用在业务层类的上面)

放在service的实现类上面,创建service对象,service对象时做业务处理,可以由事务功能的

4.@Controller(用在控制器的类上面的)

放在控制器(处理器)类的上面,创建控制器对象的,能够接受用户提交的参数,显示请求的处理结果。

5.@Value:简单类型的属性赋值(需要先创建对象注解)

属性:value是String类型的,表示简单类型的属性值
位置:
1.在属性定义的上面,无需set方法(推荐使用)

@Value给对象赋值.png

2.在set方法的上面


@Value给对象赋值2.png
6.@Autowired引用类型的属性赋值(需要先创建对象注解)

spring框架提供的注解,实现引用类型的赋值,使用的是自动注入原理,支持byName,byType

@Autowired的required属性
required是一个Boolean类型的,默认true
required=true:表示引用类型赋值失败,程序报错,终止执行。
required=false:表示引用类型赋值失败,程序正常执行,引用类型为null。

默认使用byType自动注入:
位置:
1)在属性定义的上面,无需set方法(推荐使用)

@Autowired在属性定义上.png

2)在set方法的上面


@Autowired在set方法上.png

使用byName方式:
1)在属性上面加入@Autowired

2)在属性上面加入@Qualifier(value="bean的id"):
表示使用指定名称的bean完成赋值。

执行流程:

1)


@Autowired执行流程-加载配置文件.png

2)


@Autowired执行流程-扫描类.png

3)


@Autowired执行流程-简单类型对象的创建和赋值.png

4)


@Autowired执行流程-引用类型的赋值.png
7.@Resource引用类型的属性赋值(需要先创建对象注解)

来自jdk中的注解,spring框架提供了对这个注解的功能支持,可以实现引用类型的赋值,使用的是自动注入原理,支持byName,byType

默认是byName,如果byName赋值失败,再使用byType

@Resource只使用byName方式,需要增加一个属性name(值是id的名称)

总结:

@Respotory、@Service、@Controller这三个注解的适用语法和@Component一样的。都能创建对象,但是这三个注解还有额外的功能。
@Respotory、@Service、@Controller是给项目的对象分层的。当不知道对象是持久层、业务层、控制层的,或对象就是普通类时使用@Component

配置文件最大的优点是,代码和值是分离最彻底的。故经常改动使用配置文件方便。不经常改变的使用注解。

${}的使用:

1)新建properties文件

2)在properties文件中进行赋值

语法:key=值

3)在配置文件中声明properties文件的路径

<context:property-placeholder location="properties文件路径"/>

4)在类中使用

语法:@Value("${key}")


笔记来源:B站动力节点 spring学习视频

视频链接:https://www.bilibili.com/video/BV1nz4y1d7uy

相关文章

网友评论

      本文标题:2.4基于注解的DI-第2章 IoC控制反转

      本文链接:https://www.haomeiwen.com/subject/yyutpltx.html