1. @Component, @Controller, @Repository, @Service 有何区别?
@Component:这将 java 类标记为 bean。它是任何 Spring 管理组件的通用构造型。spring 的组件扫描机制现在可以将其拾取并将其拉入应用程序环境中。
@Controller:这将一个类标记为 Spring Web MVC 控制器。标有它的 Bean 会自动导入到 IoC 容器中。
@Service:此注解是组件注解的特化。它不会对 @Component 注解提供任何其他行为。您可以在服务层类中使用 @Service 而不是 @Component,因为它以更好的方式指定了意图。
@Repository:这个注解是具有类似用途和功能的 @Component 注解的特化。它为 DAO 提供了额外的好处。它将 DAO 导入 IoC 容器,并使未经检查的异常有资格转换为 Spring DataAccessException。
2. @Required 注解有什么作用
这个注解表明 bean 的属性必须在配置的时候设置,通过一个 bean 定义的显式的属性值或通过自动装配,若 @Required 注解的 bean 属性未被设置,容器将抛出 BeanInitializationException;
1 public class Employee {
2 private String name;
3 @Required
4 public void setName(String name){
5 this.name=name;
6 }
7 public string getName(){
8 return name;
9 }
10 }
3. @Autowired和@Resource之间的区别
@Autowired默认是按照类型装配注入的,默认情况下它要求依赖对象必须存在(可以设置它required属性为false)。
@Resource默认是按照名称来装配注入的,只有当找不到与名称匹配的bean才会按照类型来装配注入。
4. @Qualifier 注解有什么作用
创建多个相同类型的 bean 并希望仅使用属性装配其中一个 bean 时,可以使用 @Qualifier 注解和 @Autowired 通过指定应该装配哪个确切的 bean 来消除歧义;
注意:@Qualifier 和 @Autowired 需要同时使用;
5. Spring支持的事务管理类型, spring 事务实现方式有哪些?
1、声明式事务,也就是使用 @Transactional 注解来实现;
2、编程式事务,使用 AOP 面向切面编程来实现事务;
6. Spring事务的实现方式和实现原理
spring 实现事务代码的方式有两种,声明式事务和编程式事务;
首先,spring 的事务是依赖于数据库的事务实现的,spring 本身是没有事务功能的;
然后,spring 的声明式事务也就是 @Transaction 注解,实现原理就是 spring aop;
通常来说,使用 aop 我们能够想到的是,前置通知中开启事务,返回通知中关闭事务,异常事务中回滚事务;
但实际上,spring aop 中并不是这么做的,而是使用 TransactionInterceptor 来实现的;
1、做准备工作,解析 @Transaction 注解上的相关属性,根据具体的属性来判断是否开启新事物;
2、获取数据库连接,关闭自动 commit 功能,开启事务;
3、执行 aop 代理的方法,也就是执行 sql 方法;
4、如果操作失败了,获取数据库连接对象,通过连接对象来执行回滚操作;
5、如果执行成功了,获取数据库连接对象,执行 commit 操作;
7. 说一下Spring的事务传播行为
传播特性共有 7 种;
事务的传播特性指的是不同方法的嵌套调用过程中,事务应该如何进行处理,是用同一个事务,还是使用不同事务;
当其中一个方法出现了异常,这两个方法的事务是提交还是回滚,也就是两个不同事务传播的方法之间的影响;
一般 7 中传播特性中常用的是 3 种:支持当前事务,不支持当前事务,嵌套事务;
支持当前事务:如果外层方法有事务,加入到该事务当中,不开启新事物;
不支持当前事务:如果外层方法有事务,不加入该事务当中,也不开启新事务;
嵌套事务:不管外层方法有没有事务,都开启当前方法的新事务;
一般情况下的判断
内外层方法是不是同一个事务:
如果是,出现异常统一由外层方法处理;
如果不是,内层方法有可能影响外层方法,外层方法不会影响内层方法;
8. 说一下 spring 的事务隔离?
spring 有五大隔离级别,默认值为 ISOLATION_DEFAULT(使用数据库的设置),其他四个隔离级别和数据库的隔离级别一致;
1. ISOLATION_DEFAULT:用底层数据库的设置隔离级别,数据库设置的是什么我就用什么;
2. ISOLATION_READ_UNCOMMITTED:未提交读,最低隔离级别、事务未提交前,就可被其他事务读取(会出现幻读、脏读、不可重复读);
3. ISOLATION_READ_COMMITTED:提交读,一个事务提交后才能被其他事务读取到(会造成幻读、不可重复读),SQL server 的默认级别;
4. ISOLATION_REPEATABLE_READ:可重复读,保证多次读取同一个数据时,其值都和事务开始时候的内容是一致,禁止读取到别的事务未提交的数据(会造成幻读),MySQL 的默认级别;
5. ISOLATION_SERIALIZABLE:序列化,代价最高最可靠的隔离级别,该隔离级别能防止脏读、不可重复读、幻读。
9. Spring的AOP的底层实现原理
首先,aop 是 ioc 的一个扩展功能,就是一个 BeanPostProcessor,当 bean 初始化完毕后,执行 BeanPostProcessor 后置处理方法时实现了 AOP 功能;
1、代理对象的创建过程(advice,切面,切点);
2、通过 jdk 或者 cglib 的方式生成代理对象;
3、在执行方法调用的时候,会调用到生成的字节码文件中,直接找回到 DynamicAdvisoredInterceptor 类的 intercept 方法,从此方法开始执行;
4、根据之前定义好的通知来生成拦截器链;
5、执行拦截器链中的每一个通知;