spring
ioc
IOC负责创建对象,管理对象(通过依赖注入(DI),装配对象,配置对象,并且管理这些对象的整个生命周期。
IOC依赖注入把应用的代码量降到最低。最小的代价和最小的侵入性使松散耦合得以实现。
spring作用域及怎么实现
singleton:容器共享一个实例,spring默认的。
实现原理:搞了一个map存放,每次从map获取。
prototype:每次会创建一个bean。
实现原理:如果是scope,bean的创建实例是在getbean的时候创建。利用了threadlocal。
request:Request作用域针对的是每次的Http请求。
session:Bean只在当前http session内是有效的。
globalSession:
bean 生命周期
1:解析xml,loadBeanDefinitions(beanFactory),把bean包装成beandefinition,放入map。如果解析到的属性
2:实例化beanfactoryPostProcessor。并且实例化实现了beanfactoryPostProcessor的接口,执行postProcessBeanFactory()
3:注册beanPostProcessor,并且解析实现了该接口的bean,此时不执行
postProcessBeforeInitialization(),postProcessAfterInitialization()方法
4:实例化->赋值属性->初始化懒加载且单例的bean,getBean()->doGetBean()->doCreateBean()->createBeanInstance()-> populateBean()->initializeBean()
4.1:判断是否已经创建好,如果创建好直接获取。如果此时发现正在创建这个bean正在创建那么抛出BeanCurrentlyInCreationException
4.2:从parentBeanFactory获取改bean。获取成功直接返回
4.3:保证当前bean所依赖的bean的初始化。如果依赖就要先创建依赖的bean。
4.4:判断作用域,是单例还是原型还是其它。
4.5:如果是单例createBeanInstance()创建实例,此时把这个创建好,但是还没有设置属性和初始化的bean放入singletonFactories。接下来populateBean()属性赋值。initializeBean()初始化,判断bean有没有实现*aware接口,执行实现了beanpostprocessor接口的postProcessBeforeInitialization(),执行InitializingBean的afterPropertiesSet()方法。反射执行init-method,执行beanpostprocessor接口的postProcessBeforeInitialization()。
5:使用
6:注册bean为可销毁的bean,销毁以后回调destory-method。
beanpostprocessor和beanfactorypostprocessor
beanPostProcessor接口中有两个方法,postProcessBeforeInitialization(),postProcessAfterInitialization()。before在bean执行init-method之前执行,after在之后执行。
beanfactorypostprocessor接口中提供了一个postProcessBeanFactory()方法。这个方法在解析完xml,就会实例化进行执行。
检测循环依赖
把bean放入singletonsCurrentlyInCreation集合,getSingleton检查singletonsCurrentlyInCreation是否已经存在,存在抛出异常。
循环依赖
b需要注入a,a需要注入b这就是循环依赖
setter怎么解决的循环依赖:
bean的初始化分为三个阶段。实例化->赋值属性->初始化。
createBeanInstance():实例化,调用对象的构造方法
populateBean():填充属性
initializeBean():调用init-method
singletonObjects用来存储已经初始化好的bean,earlysingletonObject用来存储bean实例化好,但是还没有赋值属性和初始化的bena。singletonFactories单例对象工厂,用来存提前曝光的bean。现在a依赖b,b依赖a。在实例化a完成以后把a放入singletonFactories,执行设置属性populate(),设置属性的时候发现依赖b,然后去实例化b,实例化完成以后放入singletonFactories,b继续执行设置属性,发现依赖a,此时去get的时候a已经存在singletonFactories,然后吧a放入earlysingletonObject,从singletonFactories中移除。b初始化完成以后。a设置属性,初始化。其实可以不要singletonFactories,直接放在earlysingletonObject。singletonFactories的存在是为了支持扩展。扩展aop提前代理这个类等。
构造器注入为什么不行呢?
道理很简单。因为此时bean还没有背实例化
原型为啥不行呢
原型创建bean,是在getbean的时候去创建。把创建的bean放入threadlocal。并且检查bean是都已经放入,如果放入就报错。
注解实现
获取bean的方式
ClassPathXmlApplicationContext
FileSystemXmlApplicationContext
ApplicationContextAware
WebApplicationContextUtils
aop
事务实现原理
spring中的设计模式
jdk11zgc
与标记对象的传统算法相比,ZGC在指针上做标记,在访问指针时加入Load Barrier(读屏障),比如当对象正被GC移动,指针上的颜色就会不对,这个屏障就会先把指针更新为有效地址再返回,也就是,永远只有单个对象读取时有概率被减速,而不存在为了保持应用与GC一致而粗暴整体的Stop The World。
没分代,应该是ZGC唯一的弱点了