Spring

IOC

是一个概念,是一种思想。控制反转就是对对象控制权的转移,从程序代码本身反转到了外部容器。把对象的创建、初始化、销毁等工作交给spring容器来做。由spring容器控制对象的生命周期。
控制反转:将new 的过程交给spring容器去处理。
在这里插入图片描述

DI

依赖注入DI是指程序运行过程中,若需要调用另一个对象协助时,无须在代码中创建被调用者,而是依赖于外部容器,由外部容器创建后传递给程序。依赖注入是目前最优秀的解耦方式。依赖注入让Spring的Bean之间以配置文件的方式组织在一起,而不是以硬编码的方式耦合在一起的。

Bean的作用域

在这里插入图片描述

AOP

AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Object Oriented Programming,面向对象编程)的补充和完善。
面向切面是面向对象中的一种方式而已。在代码执行过程中,动态嵌入其他代码,叫做面向切面编程。
在这里插入图片描述

AOP的实现方式

  1. 基于Schema-Base
  2. 基于AspectJ
  3. 基于注解

AOP术语介绍

在这里插入图片描述

Spring启动流程总结

Spring容器在启动的时候,先会保存所有注册进来的Bean的定义信息;

  • xml注册bean;
  • 注解注册Bean;@Service、@Component、@Bean、xxx
    Spring容器会合适的时机创建这些Bean
  • 用到这个bean的时候;利用getBean创建bean;创建好以后保存在容器中;
  • 统一创建剩下所有的bean的时候;finishBeanFactoryInitialization();
  • 后置处理器;BeanPostProcessor
  • 每一个bean创建完成,都会使用各种后置处理器进行处理;来增强bean的功能;
  • AutowiredAnnotationBeanPostProcessor:处理自动注入
  • AnnotationAwareAspectJAutoProxyCreator:来做AOP功能;
  • 事件驱动模型;
  • ApplicationListener;事件监听;
  • ApplicationEventMulticaster;事件派发:

TX(事务)

什么是事务
  事务是指是程序中一系列严密的逻辑操作,而且所有操作必须全部成功完成,否则在每个操作中所作的所有更改都会被撤消。可以通俗理解为:就是把多件事情当做一件事情来处理,好比大家同在一条船上,要活一起活,要完一起完 。

事物的四个特性(ACID)

● 原子性(Atomicity):操作这些指令时,要么全部执行成功,要么全部不执行。只要其中一个指令执行失败,所有的指令都执行失败,数据进行回滚,回到执行指令前的数据状态。

● 一致性(Consistency):事务的执行使数据从一个状态转换为另一个状态,但是对于整个数据的完整性保持稳定。

● 隔离性(Isolation):隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。

● 持久性(Durability):当事务正确完成后,它对于数据的改变是永久性的。

并发事务导致的问题

● 脏读:脏读是指在一个事务处理过程里读取了另一个未提交的事务中的数据。

● 幻读也叫虚读:一个事务执行两次查询,第二次结果集包含第一次中没有或某些行已经被删除的数据,造成两次结果不一致,只是另一个事务在这两次查询中间插入或删除了数据造成的。幻读是事务非独立执行时发生的一种现象。

● 不可重复读:一个事务两次读取同一行的数据,结果得到不同状态的结果,中间正好另一个事务更新了该数据,两次结果相异,不可被信任。

数据库事务的隔离级别

事务的隔离级别有4种,由低到高分别为Read uncommittedRead committedRepeatable readSerializable 。而且,在事务的并发操作中可能会出现脏读,不可重复读,幻读。下面通过事例一一阐述它们的概念与联系。

  • Read uncommitted(最低级别,任何情况都无法保证。)
    读未提交,顾名思义,就是一个事务可以读取另一个未提交事务的数据。

  • Read committed(可避免脏读的发生。)
    读提交,顾名思义,就是一个事务要等另一个事务提交后才能读取数据。

  • Repeatable read(可避免脏读、不可重复读的发生。)
    重复读,就是在开始读取数据(事务开启)时,不再允许修改操作

  • Serializable(可避免脏读、不可重复读、幻读的发生。) 序列化
    Serializable 是最高的事务隔离级别,在该级别下,事务串行化顺序执行,可以避免脏读、不可重复读与幻读。但是这种事务隔离级别效率低下,比较耗数据库性能,一般不使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值