前面我们已经实现了一个最简单的容器,那么接下来我们将进一步升级下。
(资料图片)
设计使用我们框架的人我们称之为客户端,我们框架要做的就是让客户端少做一些工作,然而之前的设计是让客户端来创建对象再交给容器,所以为了减轻客户端的负担,我们要让容器来为客户端创建对象。这时我们只要告诉容器,我们要的是什么类型的对象,容器便会帮助客户端创建这个对象。
于是我们有了如下设计:
1、创建一个新的对象用于包装要创建的类的类型
2、在客户端使用对象时,容器去实例化对象
实现BeanDefinition 定义将实例化交给容器做,其实可以将上节中 beanMap 中的值由 Object改为Class即可,但是为了以后的可扩展性,这里将Class包装成一个新的BeanDefinition类。比如以后可以在这个类中标记 beanClass 是否单例、是否懒加载、注入的方式等信息。
BeanFactory 定义BeanFactory 就是上节中的 SpringContainer,为什么要改为BeanFactory 呢?
原因是:这个创建对象实例的过程使用了简单工厂模式。
测试简单工厂模式的实质是由一个工厂类根据传入的参数,动态决定应该创建哪一个产品类。
工厂模式的目的:
1、解耦,将对象的使用和创建分开,解决对象间的依赖
2、隐藏复杂对象的创建过程,使用者只需要知道生产的接口即可
对比和上一节的区别,我们这里并没有自己通过 new关键词来创建对象,却可以从容器中拿到对象使用。
往期查看:
手撸Spring(一):创建简单容器