1. Spring是一个轻量级的IoC和AOP容器框架。
-
Spring的AOP理解:
- @Aspect指定一个类为切面类;
-
@Pointcut
前 后 异常 没异常 环绕
-
execution表达式
execution(<修饰符模式><返回类型模式><方法名模式>(<参数模式>)<异常模式>)
-
Spring的IoC理解:
不用new。
2. Bean生命周期以及作用域
https://www.jianshu.com/p/1dec08d290c1
-
生命周期
- 实例化(执行前后会执行**postProcessor接口对应方法)
- 依赖注入(执行后**Aware接口)
- init方法 (执行前后会执行**postProcessor接口对应方法)
- destory (执行之前disposableBean接口)
aop的实现就是在初始化 之后的postProcessor实现的
3. bean的作用域
-
普通的:
-
singleton:单例模式,
applicationContext唯一
。 - prototype:原型模式,每次获取返回不同实例,创建后的生命周期不再由IOC容器管理。
-
singleton:单例模式,
-
web中:
-
request:作用域为同一个
Http Request
。 -
session:作用域为同一个
Http Session
。 -
application:
tomcat唯一
。 - websocket:作用域为同一个WebSocket应用。
-
request:作用域为同一个
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也行,就是有点乱。
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 和 Listene
r类中注入对象,这两个是会在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);
}