菜鸟之路Day28一一分层解耦

简介: 本文《菜鸟之路Day28——分层解耦》由作者blue撰写于2025年4月29日,主要探讨软件开发中的三层架构与分层解耦概念。文章首先介绍了三层架构:Controller(控制层)、Service(业务逻辑层)和DAO(数据访问层),并深入讲解了“高内聚低耦合”的软件设计原则。接着,文章详细说明了控制反转(IOC)与依赖注入(DI)的实现方式,包括如何通过注解声明Bean对象、组件扫描以及解决多Bean冲突的方法(如@Primary、@Qualifier和@Resource)。内容结合实际开发场景,为初学者提供了清晰的指导。

菜鸟之路Day28一一分层解耦

作者:blue

时间:2025.4.29

0.概述

文章内容学习自黑马程序员BV1m84y1w7Tb

1.三层架构

image-20250429101036700.png

controller:控制层,接收前端发送的请求,对请求进行处理,并响应数据

service:业务逻辑层,处理具体的业务逻辑

dao:数据访问层(Data Access Object)(持久层),负责数据访问操作,包括数据的增,删,改,查

2.分层解耦

内聚:软件中各个功能模块内部的功能联系

耦合:衡量软件中各个层/模块之间的依赖,关联的程度

软件设计原则:高内聚低耦合

image-20250429102954345.png

如何解耦呢?

image-20250429103647634.png

控制反转(IOC):对象的创建控制权由程序自身转移到外部(容器),这种思想称为控制反转

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

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

3.IOC & DI

3.1步骤

①将Service层及Dao层的实现类,交给IOC容器管理

//在实现类上加上@Component注解
@Component //将当前类交给IOC容器管理,成为IOC容器中的bean
AI 代码解读

②为Controller及Service注入运行时,依赖的对象

//在Controller及Service所需的对应的变量上加上@Autowired注解
@Autowired //运行时,IOC容器会提供该类型的bean对象,并赋值给该变量 - 依赖注入
AI 代码解读

3.2Bean的声明

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

注意事项:

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

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

Bean组件扫描

前面声明bean的四大注解,想要生效,还需要被组件扫描注解@ComponentScan扫描

@ComponentScan注解虽然没有显示配置,但是实际上已经包含在启动类声明注解@SpringBootApplication中,默认扫描的范围是启动类所在包及其子包

3.3Bean注入

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

解决存在多个相同类型的bean的问题

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

①@Primary

@Primary //通过@Primary注解来指定使用哪一个
@Service
public class EmpServiceA implements EmpService {
   
}
AI 代码解读

②@Autowired+@Qualifier("bean的名称")

@RestController
public class EmpController {
   
    @Autowired
    @Qualifier("empServiceA")
    private Empservice empService;
}
AI 代码解读

③@Resource(name="bean的名称")

@RestController
public class EmpController {
   
    @Resource(name="empServiceB")
    private Empservice empService;
}
AI 代码解读

注意@Resource与@Autowired区别

@Autowired是spring框架提供的注解,而@Resource是JDK提供的注解

@Autowired默认是按照类型注入,而@Resource默认是按照名称注入

目录
相关文章
【组装式架构设计】架构演进简史
一步一步从单体到 SOA,从微服务再到云原生的科普后端架构演进史
28152 12
【组装式架构设计】架构演进简史
云原生时代领域驱动设计(DDD)的价值——从《没有银弹》说起
软件开发需要面对本质困难和附属困难。云原生、DevOps实践大幅降低了附属困难,使得架构师可以全力聚焦于业务复杂性,而DDD恰是管理业务复杂性的有效方法。
1649 0
云原生时代领域驱动设计(DDD)的价值——从《没有银弹》说起
大数据必知必会系列——数仓分层架构及三层架构流程[新星计划]
大数据必知必会系列——数仓分层架构及三层架构流程[新星计划]
1469 0
架构进阶之路:复杂业务开发与领域驱动设计
以下是在现公司,给成员做分享的资料。业务案例来自:一文教会你如何写复杂业务代码。作者:张建飞,进行了重新整理。
329 0
谈谈基于事件驱动的数据架构
在数字化时代,我们一直在处理数据,我相信大家已经看到了数据领域的一些结构性变化。
谈谈基于事件驱动的数据架构
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等