BeanFatory与FatoryBean
IOC与AOP
IOC: 控制反转,将bean的创建、销毁交给spring容器,所有的对象都被容器管理,主要作用是对象之间的解耦
AOP:
- 面向切面编程,通过预编译方式和运行期间动态代理实现功能的统一维护的一种技术
- AOP实现的关键在于 代理模式,AOP代理主要分为静态代理和动态代理。静态代理的代表为AspectJ;动态代理则以Spring AOP为代表。
- Spring Aop:
- 是AOP技术的实现,运行时增强,基于代理(Proxying)
- Spring AOP中的动态代理主要有两种方式,JDK动态代理和CGLIB动态代理
- AspectJ:AOP框架,编译时增强,基于字节码操作(Bytecode Manipulation)
静态代理:
- JDK动态代理: DK动态代理只提供接口的代理,不支持类的代理。核心InvocationHandler接口和Proxy类,InvocationHandler 通过invoke()方法反射来调用目标类中的代码,动态地将横切逻辑和业务编织在一起;接着,Proxy利用 InvocationHandler动态创建一个符合某一接口的的实例, 生成目标类的代理对象
- CGLIB动态代理: 如果代理类没有实现 InvocationHandler 接口,那么Spring AOP会选择使用CGLIB来动态代理目标类。CGLIB(Code Generation Library),是一个代码生成的类库,可以在运行时动态的生成指定类的一个子类对象,并覆盖其中特定方法并添加增强代码,从而实现AOP。CGLIB是通过继承的方式做的动态代理,因此如果某个类被标记为final,那么它是无法使用CGLIB做动态代理的 静态代理与动态代理区别:
- AOP代理对象的时机不同:
- 静态代理: 编辑阶段生成AOP代理类
- 动态代理: 不会去修改字节码,而是每次运行时在内存中临时为方法生成一个AOP对象
- 相对来说AspectJ的静态代理方式具有更好的性能,但是AspectJ需要特定的编译器进行处理,而Spring AOP则无需特定的编译器处理
spring aop
Spring5中通知类型
- 前置通知(Before):在目标方法被调用之前调用通知功能;
- 后置通知(After):在目标方法完成之后调用通知,此时不会关心方法的输出是什么;
- 返回通知(After-returning ):在目标方法成功执行之后调用通知;
- 异常通知(After-throwing):在目标方法抛出异常后调用通知;
- 环绕通知(Around):通知包裹了被通知的方法,在被通知的方法调用之前和调用之后执行自定义的行为。
advice的执行顺序
- 没有异常情况下的执行顺序: around before advice before advice target method 执行 around after advice after advice afterReturning
- 有异常情况下的执行顺序: around before advice before advice target method 执行 around after advice after advice afterThrowing:异常发生 java.lang.RuntimeException: 异常发生
1千万条数据插入
MySql优化
UNION ALL与UNION
- 将两个结果集合并为一个
- UNION:去重、排序
- UNION ALL:只是简单的将两个结果合并后就返回。