面试题

来源:互联网 发布:北伐战争 知乎 编辑:程序博客网 时间:2024/05/20 05:46

1:项目中如何体现Spring中的切面编程,举例说明。

      面向切面编程:主要是横切一个关注点,将一个关注点模块化成一个切面。在切面上声明一个通知(Advice)

和切入点(Pointcut);通知:是指在切面的某个特定的连接点(代表一个方法的执行。通过声明一个org.aspectj.lang.JoinPoint类型的参数可以使通知(Advice)的主体部分获得连接点信息。)上执行的动作。

通知中定义了要插入的方法。切入点:切入点的内容是一个表达式,以描述需要在那些对象的哪些方法上插入通知中定义的方法。

        项目中用到的Spring中的切面编程最多的地方:声明式事务管理。

         a:定义一个事务管理器

          b:配置事务特性(相当于声明通知。一般在业务层的类的一些方法上定义事务)

       c:配置哪些类的哪些方法需要配置事务(相当于切入点。一般是业务类的方法上)


2:spring 是什么?根据你的立即详细谈谈你的见解
  目的:解决企业应用开发的复杂性
  功能:使用基本的JavaBean代替EJB,并提供了更多的企业应用功能
  范围:任何java应用
  简单来说,spring是一个轻量级的控制反转 (loc)和面向切面的(aop)的容器框架
  轻量——从大小与开销两方面而言Spring都是轻量的。完整的Spring框架可以在一个大小只有1MB多的JAR文件里发布。并且Spring所需的处理开销也是微不足道的。此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于Spring的特定类。
  控制反转——Spring通过一种称作控制反转(IoC)的技术促进了低耦合。当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象。你可以认为IoC与JNDI相反——不是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它。
  面向切面——Spring提供了面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统级服务(例如审计(auditing)和事务(transaction)管理)进行内聚性的开发。应用对象只实现它们应该做的——完成业务逻辑——仅此而已。它们并不负责(甚至是意识)其它的系统级关注点,例如日志或事务支持。
  容器——Spring包含并管理应用对象的配置和生命周期,在这个意义上它是一种容器,你可以配置你的每个bean如何被创建——基于一个可配置原型(prototype),你的bean可以创建一个单独的实例或者每次需要时都生成一个新的实例——以及它们是如何相互关联的。然而,Spring不应该被混同于传统的重量级的EJB容器,它们经常是庞大与笨重的,难以使用。
  框架——Spring可以将简单的组件配置、组合成为复杂的应用。在Spring中,应用对象被声明式地组合,典型地是在一个XML文件里。Spring也提供了很多基础功能(事务管理、持久化框架集成等等),将应用逻辑的开发留给了你。
  所有Spring的这些特征使你能够编写更干净、更可管理、并且更易于测试的代码。它们也为Spring中的各种模块提供了基础支持。


3:容器——Spring包含并管理应用对象的配置和生命周期,在这个意义上它是一种容器,你可以配置你的每个bean如何被创建——基于一个可配置原型(prototype),你的bean可以创建一个单独的实例或者每次需要时都生成一个新的实例——以及它们是如何相互关联的。然而,Spring不应该被混同于传统的重量级的EJB容器,他们经常是庞大与笨重的,难以使用。

      框架:——Spring可以将简单的组件配置、组合成为复杂的应用。在Spring中,应用对象被声明式的组合,典型的是在一个XML文件里。Spring页提供了很多基础功能(事务管理、持久化框架集成等等),将应用逻辑的开发留给了你。

      所有Spring的这些特征使你能够编写更干净、更可管理、并且更易于测试的代码。他们页为Spring中的各种模块提供了基础支持。


4:propagation定义了7个事务传播行为:

REQUIRED:如果存在一个事务,则支持当前事务。如果没有事务则开启一个新的事物

SUPPORTS:如果存在一个事务,支持当前事务。如果没有事务,则非事务的执行。但是对于事务同步的事务管理                           器,SUPPORTS与不使用事务有少许不同。

REQUIRES_NEW:总是开启一个新的事务。如果一个事务已经存在,则将这个存在的事务挂起

NOT_SUPPORTED:总是非事务的执行,并挂起任何存在的事务。

NEVER:总是非事务的执行,如果存在一个活动事务,则抛出异常

NESTED:如果一个活动的事务存在,则运行在一个嵌套的事务中,如果没有活动事务,则按TransactionDefinition.PROPAGATION_REQUIRED属性执行。

嵌套事务一个非常重要的概念就是内层事务依赖于外层事务。外层事务失败时会回滚内层事务所做的动作。

而内层事务操作失败并不会引起外层事务的回滚。

REQUIRED应该是我们首先的事务传播行为。他能够满足我们大多数的事务要求。



原创粉丝点击