Spring-概述及IOC理论推导

文章目录

    • 优点
        • 一句话概括:
    • 程序结构
    • 原来的思路
        • 业务层service调用Dao层
        • Dao层的接口及实现类:
        • 业务层接口及实现类:
        • 不足之处
    • IOC的思想:
    • IOC本质

博客来源

优点

1、Spring是一个开源免费的框架 , 容器 .
2、Spring是一个轻量级的框架 , 非侵入式的 .
3、控制反转 IoC , 面向切面 Aop
4、对事物的支持 , 对框架的支持

一句话概括:

Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器(框架)。

程序结构

Spring-概述及IOC理论推导_第1张图片

原来的思路

业务层service调用Dao层

Dao层的接口及实现类:

Spring-概述及IOC理论推导_第2张图片
Spring-概述及IOC理论推导_第3张图片

业务层接口及实现类:

Spring-概述及IOC理论推导_第4张图片
Spring-概述及IOC理论推导_第5张图片

不足之处

当用户使用时,他是与service层交互。Dao层有四个接口的实现类。当他需要调用不同的实现类的方法时,需要去改变service层实现类UserDaoServiceImpl,可以去看,UserDaoServiceImpl是写死的,如果用户想变,那就要改动这个UserDaoServiceImpl。这无疑增加了程序员的负担,耦合较高。
Spring-概述及IOC理论推导_第6张图片

IOC的思想:

service层不要写死,通过setUserDao方法让用户传入他想用的Dao层实现类。这样就不用再频繁的改动UserDaoServiceImpl了。如果需要改动Dao层实现类的话直接改就行了。
Spring-概述及IOC理论推导_第7张图片
Spring-概述及IOC理论推导_第8张图片

IOC本质

控制反转IoC(Inversion of Control),是一种设计思想,DI(依赖注入)是实现IoC的一种方法,也有人认为DI只是IoC的另一种说法。没有IoC的程序中 , 我们使用面向对象编程 , 对象的创建与对象间的依赖关系完全硬编码在程序中,对象的创建由程序自己控制,控制反转后将对象的创建转移给第三方,个人认为所谓控制反转就是:获得依赖对象的方式反转了。
Spring-概述及IOC理论推导_第9张图片
IoC是Spring框架的核心内容,使用多种方式完美的实现了IoC,可以使用XML配置,也可以使用注解,新版本的Spring也可以零配置实现IoC。

Spring容器在初始化时先读取配置文件,根据配置文件或元数据创建与组织对象存入容器中,程序使用时再从Ioc容器中取出需要的对象。
Spring-概述及IOC理论推导_第10张图片

采用XML方式配置Bean的时候,Bean的定义信息是和实现分离的,而采用注解的方式可以把两者合为一体,Bean的定义信息直接以注解的形式定义在实现类中,从而达到了零配置的目的。

控制反转是一种通过描述(XML或注解)并通过第三方去生产或获取特定对象的方式。在Spring中实现控制反转的是IoC容器,其实现方法是依赖注入(Dependency Injection,DI)。

你可能感兴趣的:(SSM,spring)