Spring读书笔记

简介: Spring读书笔记

一、做业务需求要求

在确认需求后需要确认的几件事情:

1.项目的主流程是什么,区分分支流程和主流程

2.扩展点的预留:预留好扩展点可以为后续的扩展带来方便,同时符合开闭原则

3.扩展接口的定义:

 扩展考虑上下文传递数据结构定义

 如何满足后续需求

 兜底方案如何设计

4.职责分离

    如何抽取通用流程

5.考虑复用

    简洁代码


二、Spring中创建Bean的流程

Spring中创建Bean的流程中:

1.首先通过设置的Class属性或者根据className来解析Class,我理解这个过程其实是一个bean转beanDefintion,然后到beanDefintionMap的过程

2.对override属性进行标记以及验证

这个过程通过lookup-method和replacd-method,将methodOverrides 进行替换的过程。

3.初始化前的前后后置处理器进行增强

4.进行实例化


三、更多思考

可以看到实例化只是Spring中的一步。如果按照我们的常规思路,实现这一个实例化的过程不就行了吗?为啥还需要做这么多?

Spring框架的优秀在于它给我们留了很多口子,而这些口子就是很多框架可以很容易集成它的原因。同时这也是SpringBoot、SpringCloud很容易集成的原因。


那这给我们的思考又是什么呢?因为我们大多数人都是在写业务。也就是我们如何把这种思想在业务中使用呢?

那就是我们在这个它的整个流程中的处理器,也即我们看到的处理器。这些Processor处理器是我们看到的扩展,这种扩展的模式类似我们经常写的拦截器,前置操作、后置操作,当前操作。

也即对应我们的业务中的相关业务中的相关step,每个step,我们又可以基于此建立前置后置处理,为我们的业务处理建立扩展点,扩展是留给我们后续业务迭代的。

这个过程中,明确主流程是相当重要的,只有主流程明确,分支流程才能做更好的扩展。


这也说明了,一个好的设计,可以带来的好处有很多。


四、参考

郝佳的深入Spring源码解析

目录
相关文章
|
缓存 Java Spring
[读书笔记]Spring中的循环依赖详解
[读书笔记]Spring中的循环依赖详解
56 0
|
2月前
|
SQL 监控 druid
springboot-druid数据源的配置方式及配置后台监控-自定义和导入stater(推荐-简单方便使用)两种方式配置druid数据源
这篇文章介绍了如何在Spring Boot项目中配置和监控Druid数据源,包括自定义配置和使用Spring Boot Starter两种方法。
|
1月前
|
人工智能 自然语言处理 前端开发
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
163 2