美文网首页
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