一、IOC(Inversion of Control):控制反转

  (1)Spring Core最核心部分

  (2)需要先了解依赖注入(Denpendency Injection)/把底层类作为参数传递给上层类,实现上层对下层的“控制”

  1.IOC、DI、DL的关系:

          2.IOC容器的优势

    (1)避免在各处使用new来创建类,并且可以做到统一维护

    (2)创建实例的时候不需要了解其中的细节

  3.Spring IOC支持的功能

    (1)依赖注入  (2)依赖检查  (3)自动装配  (4)支持集合

    (5)制定初始化方法和销毁方法  (6)支持回调方法

二、Spring IOC 容器的核心接口:

  1.BeanFactory

    (1)提供IOC的配置机制

    (2)包含Bean的各种定义,便于实例化Bean

    (3)建立Bean之间的依赖关系

    (4)Bean生命周期的控制

  2.ApplicationContext的功能(继承多个接口)

    (1)Bean Factory:能够管理、装配Bean

    (2)ResourcePatternResolver:能够加载资源文件

    (3)MessageSource:能够实现国际化等功能

    (4)ApplicationEventPublisher:注册监听器,实现监听机制

  3.getBean方法的代码逻辑

    (1)转化beanName

    (2)从缓存中加载实例

    (3)实例化Bean

    (4)检测parentBeanFactory

    (5)初始化依赖Bean

    (6)创建Bean

  4.Spring Bean的作用域

    (1)Singleton:Spring默认作用域,容器里拥有唯一的Bean实例

    (2)prototype:针对每个getBean请求,容器都会创建一个Bean实例

    (3)request:为每个Http请求创建一个Bean实例

    (4)session:为每个Session创建一个Bean实例

    (5)globalSession:会为每个全局Http Session创建一个Bean实例,该作用域仅对Portlet有效

  5.Spring Bean 的生命周期

    (1)创建过程:

    (2)销毁过程:a.若实现了DisposableBean接口,则会调用destroy方法

             b.若配置了destroy-method属性,则会调用其配置的销毁方法

三、AOP

  1.AOP的三种织入方式

    (1)编译时织入:需要特殊的编译器,如AspectJ

    (2)类加载时织入:需要特殊的编译器,如AspectJ和Aspectwerkz

    (3)运行时织入:Spring采用的方式,通过动态代理的方式

  2.Advice的种类

    (1)前置通知(Before)  (2)后置通知(AfterReturning)  (3)异常通知(AfterThrowing)

    (4)最终通知(After)  (5)环绕通知(Around)

  3.AOP的实现:JdkProxy和Cglib

    (1)由AopProxyFactory根据AdvisedSupport对象的配置来决定

    (2)默认策略如果目标类是接口,则用JDKProxy来实现,否则用后者

    (3)JDKProxy的核心:InvocationHandler接口和Proxy类

    (4)Cglib:以继承方式动态生成目标类的代理

    JDKProxy:通过java的内部反射机制实现(反射机制在生成类的过程中比较高效)

    Cglib:借助ASM实现(ASM在生成类之后的执行过程中比较高效)

四、Spring事务

  (1)ACID

  (2)隔离级别

  (3)事务传播

    

    

      

Spring重要知识点整理的更多相关文章

  1. 2019年Spring核心知识点整理,看看你掌握了多少?

    前言 如今做Java尤其是web几乎是避免不了和Spring打交道了,但是Spring是这样的大而全,新鲜名词不断产生,学起来给人一种凌乱的感觉,在这里总结一下,理顺头绪. Spring 概述 Spr ...

  2. Spring MVC知识点整理

    网上Spring MVC相关知识点的介绍已经有很多了,但是大部分文章都是介绍其中的一部分知识点. 本文希望能够向读者做一个基本整体的介绍,首先我们先来了解下Spring MVC的基础接口和组件.   ...

  3. Spring MVC 知识点整理

    extend:http://www.jianshu.com/p/bef0e52067d2 1. Redis 存储方式 Redis存储机制分成两种Snapshot 和 AOF.无论是那种机制,Redis ...

  4. Spring IOC知识点一网打尽!

    前言 只有光头才能变强 回顾前面: 给女朋友讲解什么是代理模式 包装模式就是这么简单啦 单例模式你会几种写法? 工厂模式理解了没有? 在刷Spring书籍的时候花了点时间去学习了单例模式和工厂模式,总 ...

  5. JSP页面开发知识点整理

    刚学JSP页面开发,把知识点整理一下. ----------------------------------------------------------------------- JSP语法htt ...

  6. JAVA 150道笔试题知识点整理

    JAVA 笔试题 整理了几天才整理的题目,都是在笔试或者面试碰到的,好好理解消化下,对你会有帮助,祝你找工作顺利,收到满意的 offer . 1.Java 基础知识 1.1 Java SE 语法 &a ...

  7. Spring JdbcTemplate用法整理

    Spring JdbcTemplate用法整理: xml: <?xml version="1.0" encoding="UTF-8"?> <b ...

  8. ACM个人零散知识点整理

    ACM个人零散知识点整理 杂项: 1.输入输出外挂 //读入优化 int 整数 inline int read(){ int x=0,f=1; char ch=getchar(); while(ch& ...

  9. Android 零散知识点整理

    Android 零散知识点整理 为什么Android的更新试图操作必须在主线程中进行? 这是因为Android系统中的视图组件并不是线程安全的.通常应该让主线程负责创建.显示和更新UI,启动子线程,停 ...

随机推荐

  1. D9 图论综合题

    1.白银莲花池 LUOGU 2411 第一种思路:当然我们可以写三个bfs a掉这个题,这写下来一二百行要有了吧: 第二种:我们可以在一个bfs中维护所有的信息,一个方向数组,从起点开始,向八个方向扩 ...

  2. Xml & Tomcat

    文档声明: 简单声明, version : 解析这个xml的时候,使用什么版本的解析器解析 <?xml version="1.0" ?> encoding : 解析xm ...

  3. android TextView描边

    前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要重写了onDraw方法. 这一边讲一个进阶功能,实现textView的描边效果. 上效果图. 上代码: public class St ...

  4. 【转载】系统吞吐量(TPS)、用户并发量、性能测试概念和公式

    系统吞度量要素 一个系统的吞度量(承压能力)与request对CPU的消耗.外部接口.IO等等紧密关联.单个reqeust 对CPU消耗越高,外部系统接口.IO影响速度越慢,系统吞吐能力越低,反之越高 ...

  5. KMP总结

    首先给一个我能看懂的KMP讲解: http://blog.csdn.net/v_july_v/article/details/7041827 来自大神july 文章很长,但是慢慢看,会发现讲的很好. ...

  6. 三、原子变量与CAS算法

    原子变量:jdk1.5 后 java.util.concurrent.atomic 包下提供了常用的原子变量: - AtomicBoolean - AtomicInteger - AtomicLong ...

  7. WebPack命令执行的时候,其内部处理逻辑是什么

    1.首先webpack发现并没有通过命令的形式,给它指定入口和出口 2.向根目录查找“webpack.config.js”配置文件 3.解析这个配置文件,并得到配置文件中导出的配置对象 4.当拿到配置 ...

  8. spring mvc 简单的文件上传与下载

    上传文件有很多种方法,这里主要讲解的是spring mvc内提供的文件上传 前提使用:spring mvc 在这个之前我们需要把环境给配置好 1:springmvc的XML配置文件加上这一段就即可, ...

  9. structure streaming笔记

    基于micro-batch, spark2.3之后, 支持continues processing 基于spark SQL 如同在静态table上运行标准批查询一样表现流计算, spark 通过在一个 ...

  10. HTTP响应 状态码描述