spring

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

https://www.jianshu.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();
    }
    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也行,就是有点乱。
https://www.jianshu.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```注解
  • 扫包的配置问题

参考:
https://xie.infoq.cn/article/e3b46dc2c0125ab812f9aa977
https://juejin.cn/post/6911692836714840077
https://juejin.cn/post/6870391753581690894#heading-10
https://blog.csdn.net/u013189824/article/details/91579230?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-4.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-4.control
https://blog.csdn.net/qq_40297844/article/details/106939284?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-6.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-6.control

你可能感兴趣的:(spring)