美文网首页
终极搞一波

终极搞一波

作者: Pimow | 来源:发表于2018-10-30 14:10 被阅读0次

    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唯一的弱点了

    相关文章

      网友评论

          本文标题:终极搞一波

          本文链接:https://www.haomeiwen.com/subject/ohsqtqtx.html