问题:什么是控制反转(IOC),什么是依赖注入(DI)?
IOC:就是对象之间的依赖关系由Spring容器来创建,对象之间的关系本来是由我们开发者自己创建和维护的,在我们使用Spring框架后,对象之间的关系由容器来创建和维护,将开发者做的事让容器做,这就是控制反转。BeanFactory接口是Spring Ioc容器的核心接口。
DI:我们在使用Spring容器的时候,容器通过调用set方法或者是构造器来建立对象之间的依赖关系。
控制反转是目标,依赖注入是我们实现控制反转的一种手段。
问题:Java中实现依赖注入的三种方式?
构造器注入
set方法注入
接口注入
问题:Spring Bean的生命周期 ?
指Spring中bean元素被实例化,和被销毁的过程。我们通过init-method属性指定初始化方法; 通过destroy-method方法指定销毁方法。
注意:只有作用域为Singleton的时候才会有效。
问题: Spring bean元素的作用域?
当通过Spring容器创建一个Bean实例的时候,不仅可以完成bean实例的实力化,还可以为bean指定作用域。Spring bean元素的支持以下5种作用域:
Singleton:单例模式,在整个spring IOC容器中,使用singleton定义的bean将只有一个实例。
Prototype:多例模式,每次通过容器中的getBean方法获取prototype定义的beans时,都会产生一个新的bean的实例。
Request:对于每次Http请求,使用request定义的bean都会产生一个新的实例,只有在web应用时候,该作用域才会有效。
Session:对于每次Http Session,使用session定义的Bean都将产生一个新的实例。
Globalsession:每个全局的Http Sesisonn,使用session定义的本都将产生一个新的实例。
问题:Spring框架中都用到了哪些设计模式 ?
代理模式,在AOP中被使用最多。
单例模式,在Spring配置文件中定义bean的时候默认的是单例模式。
工厂模式, BeanFactory用来创建对象的实例。
Spring的注解详解
Component:修饰一个类,并将这个类给Spring管理,并且衍生出三个注解修饰类
- Controller:web层
- Service:service层
- Repository:dao层
属性注入的注解:分为两种-普通属性、对象型属性
-
普通属性:
- Value:设置普通属性
-
对象型属性:
- @Autowired :设置对象类型的属性的值。但是按照类型完成属性注入
- @Resource :完成对象类型的属性的注入,按照名称完成属性注入。必须让@Autowired注解和@Qualifier一起使用完成按照名称属性注入。
- @Autowired :设置对象类型的属性的值。但是按照类型完成属性注入
AOP
AOP面向切面编程,它是一种思想。它就是针对业务处理过程中的切面进行提取,以达到优化代码的目的,减少重复代码的目的。
AOP的使用场景: 缓存、权限管理、内容传递、错误处理、懒加载、记录跟踪、优化、校准、调试、持久化、资源池、同步管理、事物控制等。
Spring AOP的编程原理,代理机制 ?
-
JDK的动态代理:只能用于实现了接口的类产生代理。动态代理(JDK代理/接口代理) 代理对象,不需要实现接口,代理对象的生成,是利用JDK的API,动态的在内存中构建代理对象,需要我们指定代理对象/目标对象实现的接口的类型
-
Cglib代理:针对没有实现接口的类产生代理,应用的是底层的字节码增强技术,生成当前类的子类对象。Cglib代理 特点: 在内存中构建一个子类对象,从而实现对目标对象功能的扩展。
-
代理模式:
代理模式就是本该我做的事,我不做,我交给代理人去完成。就比如,我生产了一些产品,我自己不卖,我委托代理商帮我卖,让代理商和顾客打交道,我自己负责主要产品的生产就可以了。 代理模式的使用,需要有本类,和代理类,本类和代理类共同实现统一的接口。然后在main中调用就可以了。本类中的业务逻辑一般是不会变动的,在我们需要的时候可以不断的添加代理对象,或者修改代理类来实现业务的变更
AOP的相关概念: 切面(Aspect) 连接点(JoinPoint) 通知(Advice) 切入点(Pointcut) 代理(Proxy) 织入(WeaVing)
事务
原子性:事务不可分割
一致性:事务执行前后数据完整性保持一致
隔离性:一个事务的执行不应该受到其他事务的干扰
持久性:一旦事务结束,数据就持久化到数据库
- 读问题
脏读 :一个事务读到另一个事务未提交的数据
不可重复读 :一个事务读到另一个事务已经提交的update的数据,导致一个事务中多次查询结果不一致
虚读、幻读 :一个事务读到另一个事务已经提交的insert的数据,导致一个事务中多次查询结果不一致。
- 写问题
丢失更新
- 设置事务的隔离级别
Read uncommitted :未提交读,任何读问题解决不了。
Read committed :已提交读,解决脏读,但是不可重复读和虚读有可能发生。
Repeatable read :重复读,解决脏读和不可重复读,但是虚读有可能发生。
Serializable :解决所有读问题。