首页 > 其他分享 >分层解耦、IOC和DI

分层解耦、IOC和DI

时间:2023-08-03 19:23:46浏览次数:41  
标签:Service DI Autowired bean 分层 Controller 注解 IOC

学习教程:【黑马程序员2023新版JavaWeb开发教程,实现javaweb企业开发全流程(涵盖Spring+MyBatis+SpringMVC+SpringBoot等)】 https://www.bilibili.com/video/BV1m84y1w7Tb/?p=161&share_source=copy_web&vd_source=2c07d62293f5003c919b2df9b2e0549e

分层解耦

三层架构

在进行软件设计和软件开发时,需要让每个接口、类或方法的职责更加单一,即单一职责原则。基于此在Web开发中就有了三层架构。

  • Controller层:控制层,接收前端发送的请求,对请求进行处理,并响应数据。
  • Service层:业务逻辑层,处理具体的业务逻辑。
  • Dao层:数据访问层(Data Access Object)(持久层),负责数据访问操作,包括数据的增,删,改,查。

个人理解:由Controller层接受请求,然后向Service层拿需要响应的数据,Service层又向Dao层获取原始数据,Dao层就从数据源获取数据,然后返回给Service层,Service层再对原始数据进行逻辑处理,将处理好的数据再返回给Controller层,Controller层再将这个拿到的处理好的数据响应给请求方。这样三层,每一层负责各自的职业,提高了代码复用性,利于维护和扩展,分层解耦。

分层解耦

  • 内聚:软件中各个功能模块内部的功能联系。
  • 耦合:衡量软件中各个层/模块之间的依赖、关联的程度。
  • 软件设计原则:高内聚、低耦合。

控制反转:Inversion Of Control,简称IOC对象创建控制权由程序自身转移到外部(容器),这种思想称为控制反转。Spring就是使用IOC思想,通过使用反射机制,帮我们实例化并放进容器中,由容器来管理。

依赖注入:Dependency Injection,简称DI。容器为应用程序提供运行时,所依赖的资源,称之为依赖注入。

Bean对象:IOC容器中创建、管理的对象,称之为bean

个人理解:通过控制反转让容器管理对象,我们只需要设计好类,对象的实例化和存放交给容器,容器再通过依赖注入将程序需要的对象给程序。通过这种方式可以降低各个模块之间的耦合,不需要在模块中再实例化其他模块的对象。

IOC详解(SpringBoot)

Bean的声明

要把某个对象交给IOC容器管理,需要在对应的类上加上如下注解之一:

注解 说明 位置
@Component 声明bean的基础注解 一般不属于以下三类时,用此注解
@Controller @Component的衍生注解 标注在控制器类(Controller层)
@Service @Component的衍生注解 标注在业务类上(Service层)
@Repository @Component的衍生注解 标注在数据访问类上(Dao层)(由于与mybatis整合,用的少)

注意事项:

  • 声明bean的时候,可以通过value属性指定bean的名字,如果没有指定,默认为类名首字母小写。

    @Repository("daoA")

  • 使用以上四个注解都可以声明bean,但是在SpringBoot集成开发web开发中,声明控制器bean只能用@Controller。

Bean组件的声明

  • 前面声明的四大注解,要想生效,还需要被组件扫描,注解@ComponentScan扫描。
  • @ComponentScan注解 虽然没有显示配置,但是实际上已经包含在了启动类声明注解 @SpringBootApplication 中,默认扫描范围是启动类所在包及其子包,也可以通过@ComponentScan的value和basePackages属性手动指定扫描范围,但是一般不手动指定。

DI详解(SpringBoot)

  • @Autowired注解,默认是按照类型进行自动装配,如果存在多个相同类型的bean,将会报错。

  • 可以通过以下几种方案来解决:

    • @Primary:如果有多个相同类型的bean对象,可以通过改注解设置优先级,有该注解的优先生效。

    • @Autowired + @Qualifier("bean的名称"):通过该注解,()中填入bean对象名称,可以指定需要的bean对象,需要配合@Autowired使用。

    • @Resource(name = "bean的名称"):按照bean名称进行注入,指定需要注入的bean对象,不需要@Autowired。

  • @Resource 与 @Autowired 区别

    1. @Autowired 是spring框架提供的注解,而@Resource是JDK提供的注解。
    2. @Autowired 默认是按照类型注入,而@Resource 是默认按照名称注入。

弹幕引用:

  1. 注意,并不是只按照类型或者名字,是先按照什么找,找不到再按照什么找,而这里的名字和类型都是以你注入的地方的变量名和变量类型开找;

  2. Resource如果不写name属性则是按照类型注入哈;

标签:Service,DI,Autowired,bean,分层,Controller,注解,IOC
From: https://www.cnblogs.com/zh-Note/p/17604220.html

相关文章

  • 怎么设置centos限定redis使用的内存
    1、Redis-Cluster集群2、怎么设置centos限定redis使用的内存3、高性能高并发网站架构,教你搭建Redis5缓存集群4、Redis-Cluster5、「实用教程」在配备持久内存的实例上部署Redis应用Redis-Cluster集群1、连接如下https://redis.io/topics/cluster-tutorial以下步骤是在一......
  • wangEditor 图片粘贴上传,实现图文粘贴,图片自动上传
    ​ 1.编辑器修改(可选) 1.1在 ueditor/config.json 中添加代码块    /* 上传word配置 */    "wordActionName":"wordupload",/* 执行上传视频的action名称 */    "wordFieldName":"upfile",/* 提交的视频表单名称 */    "wordPathFormat":......
  • 官宣 | CODING 荣获可信云软件研发效能度量平台先进级最高评估成果
    点击链接了解详情2023年7月25日,由中国信息通信研究院(以下简称“中国信通院”)和中国通信标准化协会联合主办的2023可信云大会在北京召开。大会以“云领创新算启新篇”为主题,发布了《云计算白皮书(2023年)》《中国算力服务研究报告(2023年)》,解读了2023云计算十大关键词,......
  • 虹科干货 | DevOps 团队为什么独独青睐 Redis Enterprise ?
    快速部署是保障成功的DevOps的关键要素。虹科RedisEnterprise提供了一种快速的数据库。01DevOps团队面临的挑战1.提高应用程序处理速度,赢得商业竞争许多企业中,DevOps团队(DevOps是一组过程、方法与系统的统称,用于促进开发、技术运营和质量保障部门之间的沟通、协作与整合)正......
  • 虹科分享 | 妙招频出,Redis 企业版这样解决缓存问题→
    为什么企业需要数字化?数字化转型的根本目的是什么?数据的缓存为什么如此的重要?虹科RedisEnterprise又能够在哪些方面助力企业解决数据处理难题?01当前数据库缓存面临的挑战:使用当前数据库实现速度和可扩展性实现满足用户期望所需的数据性能并不容易。企业需要应对遗留基础设施、缓......
  • IDEA必备插件之Sequence Diagram,你GET了么?
    前言“无论是快速了解业务流程,还是快速的熟悉系统的业务代码逻辑,以及各个类和方法等的调用关系,时序图无疑是其中一种不可获取的简便快捷的方式。一起来了解下,IDEA如何快速生成时序图吧。”工作中,经常需要绘制时序图说明业务流程的设计走向,而逻辑较复杂的时序图,若是单纯的通过人......
  • 使用redis-py的两个类Redis和StrictRedis时遇到的坑
    redis-py提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用官方的语法和命令(比如,SET命令对应与StrictRedis.set方法)。Redis是StrictRedis的子类,用于向后兼容旧版本的redis-py。简单说,官方推荐使用StrictRedis方法。  不推荐Redis类,原......
  • pyredis使用场景
    1.安装pyredis首先安装pip <SHELL>#apt-getinstallpython-pip......<SHELL>#pipinstall--proxy=http://172.1.2.6:8080redisDownl......
  • 在DIALOG菜单栏里设置的全选(取消全选)或选择功能
     全选和取消全选: 选择和取消选择: ......
  • 巧用Redis实现分布式锁详细介绍_Redis
    目录前言手写Redis分布式锁Redissonlock()lock(longleaseTime,TimeUnitunit)tryLock(longwaitTime,longleaseTime,TimeUnitunit)RedLock红锁总结前言无论是synchronized还是Lock,都运行在线程级别上,必须运行在同一个JVM中。如果竞争资源的进程不在同一个JVM中时,......