Spring IoC、容器初始化、对象

目录 

概要

IoC控制反转

loC的引入【重点理解】

loC容器

代码角度

1.基于XML配置的做法

工厂方法

Spring容器的初始化过程

回归对象本身

2. 基于注解的做法


概要

简单介绍Spring是什么?
https://spring.io/

软件工程学科不是为计算机硬件考虑的,而是为了写程序的人类在考虑。

IoC控制反转

loC的引入【重点理解】

对象按照各自职责,再做进一步的类型分割【从 Java语言层面,所有对象都是平等的,没有任何区别;但在我们脑海中逻辑上有区别】

loC思想——依赖DI的形式
正向控制、控制反转,两者只是从不同角度描述同一件事情。随着软件规模发展,对象的经济模式不可避免地从“小农经济”发展到“商品经济”了。

loC容器

代码角度

1.基于XML配置的做法

售卖、生产

购买

既是买方又是卖方

工厂方法

以静态工厂方法方式售卖对象(自己 new好对象再卖给Spring)
由于,Java中所有的代码都得挂靠在某个方法里,方法又得挂靠在某个类上,如果不想有对象就直接调用方法,可选的方案只有使用静态方法,这种专门用来实例化对象的方法一般称为工厂方法(factory method)。


City (对象)
工厂类+工厂方法: City CityFactory.create(...)

Spring容器的初始化过程

回归对象本身

MVC : Model / View / Controller

最原生主义下的MVC:
View:用来处理展示相关流程的对象【过程对象】

Controller:用来处理数据加工流程的对象【过程对象】

Model :
1.数据对象
2.获取数据对象的过程对象
只要场景不是太大,基本上MVC三层就可以把整个应用划分出来了


在用户登录场景下:
Model:
1.User类
2.从数据中获取User 数据的类
Controller:根据得到的User 数据,做好判断
View:以HTML显示用户?以JSON显示用户?以其他格式等


Java视角下的各种不同类型的对象:
1. 过程对象:
Controller/控制器(SSM中的@Controller 注解就是这个延续)
主要处理HTTP资源相关动作:
1.读取用户参数、判断合法性
2.HTTP响应:状态码、重定向、响应头
Service/服务
1.从各种数据聚合整理,变换结构等
Repository / Data Access Object DAO / Mapper
1.从数据存储中(MySQL等)获取数据

2. 数据对象:
Model / Entity (实例) / DataObject(刚从数据库中取出来的对象)

BussinessObject (业务抽象对象) / ViewObject(为了展示的对象)


其实不会让所有对象都交给Spring去管理,一般来说:
过程对象才会交给Spring 去管理—— Spring管理的对象默认就是单例的。

2. 基于注解的做法

工厂方法注册 @Bean

强调,尤其是属性注入的情况下,这个类只有注册到Spring 下,被Spring 实例化出来才能进行注入。手动 new出来的对象,是无法注入的!

原因:只有让Spring去实例化对象,它才有机会进行属性注入。我们手动 new对象,Spring 介入不了,没办法进行属性注入。


 什么时候应该用@Component 系列进行类的注册,什么时候应该用@Bean进行工厂方法注册?
依据:当要注册的类,是我们自己写的,我们能添加注解去修饰类,就用@Component系列进行注册;
反之,当类不是我们自己写的,不能改别人代码,为类添加注解,就用@Bean的工厂方式方式注册。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

瘦皮猴117

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值