news 2026/2/7 2:57:12

(29)阶段性个人总结

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(29)阶段性个人总结

至此我们已经学完spring中最大两个的特性之一IoC

为什么要有Ioc?

在传统的项目中我们发现我们的程序通过new的方式来创建对象的时候,耦合度较高,下层改变了什么(比如说换了个数据库),上层的代码就要跟着改变,实际上这是我们不希望看到的。它违反了依赖倒置,也使得系统难以扩展,这也不符合OCP开闭原则,(对扩展开放, 对修改关闭),所以这时候spring出来了,它帮我们进行对象的实例化,同时维护类的关系。

springIoc的原理

Spring IoC 容器通过多种机制创建 Bean 实例(包括但不限于构造方法),并通过 setter 方法或构造方法参数完成依赖注入。对于普通 POJO,默认使用反射调用构造方法创建对象;但对于工厂、代理等高级场景,则委托用户代码控制实例化过程。

  • Spring 在启动时会解析配置文件,注册所有 BeanDefinition(包含类创建时所需要的信息);对于singleton 作用域的 Bean(非懒加载),会在容器刷新阶段完成实例化和初始化。

    • 解析配置文件
      Spring 通过 XML 解析器(如 DOM4J 或 JDK 内置解析器)读取配置文件,提取 <bean> 标签中的 id、class、属性值等信息,构建 BeanDefinition。,取出spring要的信息(bean的id,全路径参数,为简单类型赋值的属性值等等)。
    • bean创建
      因为spring的配置文件中我们把类的全路径都给了spring,所以它可以通过反射创建出这个类。Spring 在创建每个 Bean 时,会递归解析其依赖:若依赖的 Bean 尚未创建,则立即转去创建它。
    • 对象的存储
      在一个map(String,Object)集合中以key存id,value存这个具体的类的方式存储这个bean。单例 Bean 最终存储在singletonObjects(一级缓存)中,但在创建过程中还会用到二级、三级缓存以支持循环依赖。
    • bean的赋值
      属性赋值发生在该 Bean 实例化之后、初始化之前。遍历所有集合将对象取出来,分两种类型,判断一下。为复杂属性赋值:我们直接通过id把这个类取出来赋值即可;为简单属性赋值:我们需要判断这串字符串的类型(有工具包,或者一个一个的判断),然后转成对应的类型为字段赋值。补充:Spring 使用 TypeConverter + PropertyEditor 机制进行类型转换,例如:
  • 注意:按需创建 + 提前暴露早期引用(三级缓存)来解决循环依赖。

  • 解决循环依赖具体步骤:

    1. 创建 A(调用构造器 → 得到原始对象)
    2. 将 A 的ObjectFactory放入三级缓存
    3. 开始给 A 赋值,发现依赖 B
    4. 转去创建 B
    5. 原始对象创建后,立刻暴露 ObjectFactory 到三级缓存
    6. 给 B 赋值,发现依赖 A
    7. 当 B 需要注入 A 时,Spring 从三级缓存中通过 ObjectFactory 获取 A 的早期引用(尚未完成属性注入和初始化),并将其注入给 B。”
    8. B 初始化完成 → 放入一级缓存
    9. 回到 A,注入已创建的 B
    10. A 初始化完成
  • bean的实例化的方式其实有多种
    Spring 提供了多种 Bean 实例化方式以适应不同场景。虽然它们在容器中表现为统一的 Bean 实例,但底层创建机制并不相同:有些通过构造方法,有些通过工厂方法,有些甚至返回代理或复用对象,并非都依赖目标类的构造方法。

  • bean的作用域

    • bean标签的scope属性指明了bena的作用域的范围,默认为单例形式,即一个程序中一个id只有一个的bean,而对于 prototype 作用域的 Bean则对数量没有限制,它完全交给了客户端代码处理
    • 注意:循环依赖仅在singleton 作用域 + setter/field 注入下被 Spring 支持;prototype、request 等作用域不支持循环依赖。
  • 实例化只是bean的生命周期的前面两步

    • 第一步:创建Bean
    • 第二步:Bean属性赋值
    • 第三步:初始化Bean
    • 第四步:使用Bean
    • 第五步:销毁Bean

注解加入后流程的变化:

注解的存在主要是为了简化XML的配置。Spring6后倡导全注解开发
前情提要:
@Controller、@Service、@Repository这三个注解都是@Component注解的别名
在类上加上注解后,我们便不需要在xml文件中书写bean标签了,我们只需要在xml文件中指定扫描的包就行了,实际上连这一步也可以在属性类上配置,所以可以说有了注解,我们便离开了传统的麻烦的在xml文件中书写bean标签的方式。

那么spring到底是如何实现的这一方法的呢?

其背后的核心机制是组件扫描(Component Scanning) + 注解元数据解析 + BeanDefinition 注册
java配置类中:

@Configuration@ComponentScan("com.powernode.spring6")publicclassAppConfig{}

  1. Spring 使用ResourcePatternResolver扫描classpath下的 .class 文件
    通过 ASM(字节码分析库)读取类的注解信息(避免加载类到 JVM,提升性能)
    只有在真正需要实例化时,才通过Class.forName()加载类并反射创建
    这解释了为什么 Spring 启动快 —— 扫描时不加载类,只读字节码元数据。
  2. 查看类上是否有注解@Component及其其派生注解
  3. 有的话创建一个BeanDefinition类,里面记录了创建类所用到的信息
  4. BeanDefinition注册到BeanFactory
  5. 后续流程与 XML 方式完全一致
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/5 22:35:02

jQuery UI 实例 - 对话框(Dialog)

jQuery UI Dialog&#xff08;对话框&#xff09;实例 Dialog 是 jQuery UI 中最常用的组件之一&#xff0c;用于创建模态或非模态弹出窗口&#xff0c;常用于确认提示、表单编辑、内容预览、登录框、提示消息等。它支持拖拽、缩放、按钮、动画、自动居中等功能。 官方演示地…

作者头像 李华
网站建设 2026/2/5 20:44:17

模型版本迭代中的回归测试策略

回归测试在模型迭代中的核心价值 在人工智能与机器学习模型快速演进的今天&#xff0c;软件系统频繁更新已成为常态。每一次模型版本迭代——无论是参数调整、架构优化还是新功能引入——都可能引入意想不到的副作用&#xff0c;导致原有功能衰退。回归测试作为软件质量保障的…

作者头像 李华
网站建设 2026/2/4 3:15:28

【Open-AutoGLM家务提醒安排】:揭秘智能家庭任务调度背后的AI黑科技

第一章&#xff1a;Open-AutoGLM家务提醒安排在智能家居场景中&#xff0c;利用大语言模型自动化处理日常任务正变得越来越普及。Open-AutoGLM 是一个开源框架&#xff0c;专为家庭事务调度设计&#xff0c;支持通过自然语言理解生成家务提醒&#xff0c;并与智能设备联动执行。…

作者头像 李华
网站建设 2026/2/6 22:10:26

Open-AutoGLM食材购买避坑指南:90%人忽略的3类关键营养匹配原则

第一章&#xff1a;Open-AutoGLM 食材购买推荐在构建 Open-AutoGLM 推理系统时&#xff0c;选择合适的硬件和软件“食材”至关重要。这些组件共同决定了模型运行的效率、响应速度以及扩展能力。核心硬件配置建议 GPU&#xff1a;推荐使用 NVIDIA A100 或 RTX 4090&#xff0c;支…

作者头像 李华
网站建设 2026/2/5 4:34:32

Open-AutoGLM任务中断恢复实战(断点续训技术大揭秘)

第一章&#xff1a;Open-AutoGLM任务中断恢复概述 在大规模语言模型训练与推理过程中&#xff0c;任务执行可能因硬件故障、网络中断或资源调度异常而意外终止。Open-AutoGLM 作为支持自动化代码生成与任务调度的框架&#xff0c;提供了任务中断恢复机制&#xff0c;确保长时间…

作者头像 李华