Spring(一):IOC如何推导和理解
目录
- IOC的推导
- 1.1、模拟一个正常查询信息的业务流程:
- 1.2、多个种类的查询
- 1.3、优化查询方式
- 1.4、IOC本质
IOC的推导
1.1、模拟一个正常查询信息的业务流程:
①mapper层:因为没有连接数据库,这里我们写一个mapper的实现类来模拟数据的查询
public interface PerMapper {void getPerInfo(); }public class StudentMapperImpl implements PerMapper {@Overridepublic void getPerInfo() {System.out.println("我是一个学生"); }}
②service层:service的作用是查询人的信息
public interface PersonService {void getPersonInfo(); }public class PersonServiceImpl implements PersonService {private PerMapper studentMapper = new StudentMapperImpl(); @Overridepublic void getPersonInfo() {studentMapper.getPerInfo(); }}
③contorller层
import service.PersonService; import service.impl.PersonServiceImpl; public class IOCTest {public static void main(String[] args) {PersonService service = new PersonServiceImpl(); service.getStudentInfo(); }}
【Spring(一):IOC如何推导和理解】④执行结果如下:
文章图片
image
1.2、多个种类的查询
①mapper,增加老师实现类
public class TeacherMapperImpl implements PerMapper {@Overridepublic void getPerInfo() {System.out.println("我是一个老师"); }}
②这时候我们同时查询教师和学生的信息该怎么做呢?
public class PersonServiceImpl implements PersonService {private PerMapper student = new StudentMapperImpl(); private PerMapper teacher = new TeacherMapperImpl(); @Overridepublic void getPersonInfo() {student.getPerInfo(); teacher.getPerInfo(); }}
③执行结果:
文章图片
image
④如果需求再次变更呢?只需要教师的信息怎么做呢? 毋庸置疑:两种做法, 一种是直接更改PersonServiceImpl的getPersonInfo()
@Overridepublic void getPersonInfo() {//student.getPerInfo(); teacher.getPerInfo(); }
第二种是扩展service层的接口,把老师和学生分别提供接口来查询:
public interface PersonService {void getPersonInfo(); void getPersonInfo1(); }public class PersonServiceImpl implements PersonService {private PerMapper student = new StudentMapperImpl(); private PerMapper teacher = new TeacherMapperImpl(); @Overridepublic void getPersonInfo() {teacher.getPerInfo(); }@Overridepublic void getPersonInfo1() {student.getPerInfo(); }}
⑤看起来好像没啥问题是吧?那假如有一百种人呢?需要改来改去人都会疯掉的。这种做法肯定不合理的!
1.3、优化查询方式
①聪明的孩子可以想到将查询的对象剥离出来:添加 set() 方法,对接口不实现,只进行预留的工作。
public class PersonServiceImpl implements PersonService {private PerMapper per; public void setPer(PerMapper per) {this.per = per; }@Overridepublic void getPersonInfo() {per.getPerInfo(); }}
②controller层实现方式:
public class IOCTest {public static void main(String[] args) {PersonServiceImpl service = new PersonServiceImpl(); //学生service.setPer(new StudentMapperImpl()); service.getPersonInfo(); //老师service.setPer(new TeacherMapperImpl()); service.getPersonInfo(); }}
③总结:这种方式就是把主动权交给了调用者 ,程序不用去管怎么创建,怎么实现了 .,它只负责提供一个接口 。
我们不再去管理对象的创建了 , 更多的去关注业务的实现 ,耦合性大大降低 ,这也就是IOC的原型 !
1.4、IOC本质
控制反转是一种通过描述(XML或注解)并通过第三方去生产或获取特定对象的方式。在Spring中实现控制反转的是IOC容器,其实现方法是依赖注入(Dependency Injection,DI)。
推荐阅读
- SpringBoot|SpringBoot feign动态设置数据源(https请求)
- 从零开始,开发一个|从零开始,开发一个 Web Office 套件(6)(光标 & Click 事件)
- Orange,跨平台文件搜索引擎
- 数睿数据深度 | 商业智能红海,下一代BI还能激起多大的浪花
- 一文告诉你Excel融合分析如何利用Smartbi实现仪表盘效果
- 测试工具学习|adb 学习
- 测试工具学习|Charles 基础使用
- Java|JavaScript基础
- JavaSE|异常学习笔记
- CVE-2022-22947|CVE-2022-22947 Spring Cloud Gateway SPEL RCE复现