spring

1. Spring是一个轻量级的IoC和AOP容器框架。
  • Spring的AOP理解:
    • @Aspect指定一个类为切面类;
    • @Pointcut 前 后 异常 没异常 环绕
    • execution表达式
      execution(<修饰符模式><返回类型模式><方法名模式>(<参数模式>)<异常模式>)
  • Spring的IoC理解:
    不用new。
2. Bean生命周期以及作用域

//www.greatytc.com/p/1dec08d290c1

  • 生命周期
    1. 实例化(执行前后会执行**postProcessor接口对应方法)
    2. 依赖注入(执行后**Aware接口)
    3. init方法 (执行前后会执行**postProcessor接口对应方法)
    4. destory (执行之前disposableBean接口)

aop的实现就是在初始化 之后的postProcessor实现的

3. bean的作用域
  • 普通的:

    • singleton:单例模式,applicationContext唯一
    • prototype:原型模式,每次获取返回不同实例,创建后的生命周期不再由IOC容器管理。
  • web中:

    • request:作用域为同一个 Http Request
    • session:作用域为同一个 Http Session
    • applicationtomcat唯一
    • websocket:作用域为同一个WebSocket应用。

https://www.cnblogs.com/mfrank/p/10498056.html

4. BeanFactory和ApplicationContext有什么区别?

beanFactory实现了bean的生命周期和控制,基本功能。
applicationContext在之上包了一层,实现了资源统一读取加载多个配置文件功能以及监听器

5. spring事务

事务失效

  • 方法private。
  • 异常被捕获了异常得是非受检,要不得加rollbackfor说明。
  • 同一个类中方法调用。
  • 数据库不支持。

发生方法调用会失效

A class{
    public a(){
//事务失效
        b();
    }
    @事务声明
    public b(){
    }
}

调用A的a方法 b中是不会走事务的,因为事务是会生成的代理类上。
调用a会执行a.b()不会执行事务代码,因为这时候调用的不是代理类的b方法。

A.Proxy class{
    A a;
    public a(){
        a.a();
        a.b();
    }
    public b(){
        开启事务
            a.b();
        关闭事务
    }
}

事务数据库和代码都设置
代码为主。

保证一次连接
ThreadLocal一个线程。

支持的传播范围
a->b,b有事务注解。当前事务就是看a或者上级有没有事务。
1 . 默认required当前事务有事务就加入,没有就新建事务。
2 .requires_new,当前事务有没有事务,都要新建一个事务,外层事务不影响里层事务。
3.嵌套类似默认,当前事务有事务就加入,没有就新建事务。不同的是外层会影响里层事务,外层回滚里层也回滚。
4.支持当前事务有事务就加入,没有就不走事务。
5.强制得走事务,当前事务没有事务,抛异常。
6.不支持当前事务有无事务都不走事务。
7.never当前事务有无事务都不走事务,但是有事务会抛异常。

6. spring循环引用

3层缓存 3个map,一个map也行,就是有点乱。
//www.greatytc.com/p/64d422217685?utm_campaign=haruki&utm_content=note&utm_medium=reader_share&utm_source=weixin

  • singletonFactories : 代理类(三级缓存)
  • earlySingletonObjects :半成品类(二级缓存)
  • singletonObjects:完整类(一级缓存)

二级缓存主要是做提前曝光,因为在对象b依赖注入的时候,a还没有init不能放进一级,所以取不到a对象。
正常的aop增强是发生在初始化之后,但是代理后不是之前的对象了。
所以在图中红圈步骤里,把这个对象的代理对象放入3级缓存中。
当蓝箭头处,发现了循环引用,把3级缓存中的a对象代理放入2级缓存中,然后b对象里就是a的代理。

注入方法
@Autowired字段,@Autowired写setter方法,构造方法。
第一个最简单,虽然不推荐,也不会出啥问题。后面2个可以在注入的时候检查下。

注入失败情况

  • new创建对象
  • Filter 和 Listener类中注入对象,这两个是会在spring 容器加载bean之前。
  • 服务impl v没有加@Service```注解
  • 扫包的配置问题
7. 事件监听

事件 ApplicationEvent 一个long类型的时间戳,一个object事件对象。
监听器ApplicationListener.onApplicationEvent()
触发 ApplicationContext .publishEvent()
相关应用nacos
NacosAutoServiceRegistration实现了ApplicationListener<WebServerInitializedEvent>接口,监听WebServerInitializedEvent事件(容器启动事件),在spring容器启动的时候,会调用其重写的onApplicationEvent方法。
NacosAutoServiceRegistration在nacos的jar包,spring.factiors中声明,在启动时会把这个类当作配置类,构造方法上有@bean注解,会在满足@ConditionalOnBean条件时,把方法返回的bean注入到容器。

    @Bean
    @ConditionalOnBean(AutoServiceRegistrationProperties.class)
    public NacosAutoServiceRegistration nacosAutoServiceRegistration(
            NacosServiceRegistry registry,
            AutoServiceRegistrationProperties autoServiceRegistrationProperties,
            NacosRegistration registration) {
        return new NacosAutoServiceRegistration(registry,
                autoServiceRegistrationProperties, registration);
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容