题目
1.谈谈Spring IOC的理解,原理与实现。
2.谈一下spring IOC的底层实现。
3.描述一下bean的声明周期。
4.Spring是如何解决循环依赖的问题的?
5.Bean Factory 与FactoryBean有什么区别?
6.Spring中用的设计模式?
7.Spring的AOP的底层实现原理。
8.Spring的事务是如何回滚的。
9.谈一下spring事务传播。
答题技巧
总:当前问题回答的是哪些具体的点
分:以1,2,3,4,5的方式分细节取描述相关的知识点,如果有哪些点不清楚,直接忽略过去。
突出一些技术名词(核心概念、接口、类、关键方法)
避重就轻,不会的不要说,引导面试提问。避免没有重点。
1.谈谈Spring IOC的理解,原理与实现。
总
控制反转:理论思想,原来的对象是由使用者来进行控制,有了spring之后,可以把整个对象交给spring来帮我们进行管理。
DI:依赖注入,把对应的属性的值注入到具体的对象中。
在Spring哪些地方设计到DI:
@Autowired
populateBean完成属性值的注入
容器:存放对象,使用map结构来存储,在spring中一般存在三级缓存。singletonObject存放完整的bean对象。整个bean的生命周期,从创建到使用到销毁的过程全部都是由容器来管理(bean的生命周期)。
分
1.一般聊IOC容器的时候要设计到容器的创建过程,提到beanFacroty,DefaultListableBeanFactory. 容器有一个最顶层的接口beanFactory,没有提供对应的子类实现。
向bean工厂中设置一些参数(BeanPostProcessor,Aware接口的子类)等等属性。
2.加载解析bean对象,准备要创建的bean对象的定义对象beanDefinition(xml,或者注解的解析过程)。
3.beanFacctoryPostProcessor的处理,此处是拓展点,PlaceHolderConfigureSupport,ConfigurationClassPostProcessor。
4.BeanPostProcessor的注册功能,方便后续对bean对象完成具体的拓展功能。
5.通过反射的方式将BeanDefinition对象实例化成具体的bean对象。
6.bean对象初始化过程(填充属性,调用aware子类的方法,调用BeanPostProcessor前置处理方法,调用init-method方法,调用BeanPostProcessor后置处理方法)
7.生成完整的bean对象,通过getBean方法可以直接获取。
8.销毁过程。
面试官,这是我对ioc的整体理解,包含了一下详细的处理过程,你看一下有什么问题,可以指点我一下。(前提是你把整个流程说完)
一个问题能占用面试官多少时间。一个小时问20个问题能回答多少?问的越多可能露馅越多。当面试官问到一个你熟悉的点的时候,一定要尽量拖时间。
老师,我没看过源码怎么办。具体的细节我记不太清了,但是spring中的bean都是通过反射的方式生成的, 同时其中包含了很多的拓展点,比如最常用的对BeanFactory的拓展,对bean的拓展(对占位符的处理)。我们公司对这方面的使用是比较多的,除此之外,IOC中的最核心的也就是填充具体bean的属性,和生命周期(背一下)。
面试过程中不要在简历的背面上画东西,尊重自己的简历。
2.谈一下spring IOC的底层实现。
底层实现
工作原理
过程
数据结构
流程
设计模式
设计思想
以上都不用谈
就是谈你对他的理解和你了解过的实现过程。
反射
工厂
设计模式
会的说不会的不说,关键的几个方法
createBeanFactory,
getBean,
doGetBean,
createBean,
doCreateBean,
createBeanInstance(getDeclaredConstructor,newInstance)
populateBean
initializingBean
1.先通过createBeanFactoy创建一个Bean工厂(DefaultListableBeanFactory)
2.开始循环创建对象,因为容器中的bean默认都是单例的,所以优先通过getBean,doGetBean从容器中查找,找不到的话
3.通过createBean,doCreateBean方法,以反射的方式创建对象,一般情况下使用的是无参的构造方法(getDeclaredConstructor,newInstance)
4.进行对象的属性填充populateBean
5. 进行其他的初始化操作(initializingBean)。