SSH面试题

 

一、选择题 (每题2分 共20分)

1、关于spring说法错误的
 A.spring是一个轻量级JAVA EE的框架集合
 B.spring包含一个“依赖注入”模式的实现
 C.使用spring可以实现声明事务
 D.spring提供了AOP方式的日志系统
 
  
2、 依赖注入说法正确的

 A.依赖注入的目标是在代码之外管理程序组建间的依赖关系

 B.依赖注入即是“面向接口”的编程

 C.依赖注入是面向对象技术的替代品

D.依赖注入的使用会增大程序的规模

3、关于AOP错误的
 A. AOP将散落在系统中的“方面”代码集中实现
 B. AOP有助于提高系统可维护性
 C. AOP已经表现出将要替代面向对象的趋势
 D. AOP是一种设计模式,Spring提供了一种实现

4、关于spring AOP错误的
 A.首先要编写方面代码,实现MethodBeforeAdvice接口
 B.AOP采取拦截方法调用方式实现,可以在调用方法前,后,抛出异常时拦截
 C.AOP采取代理的方式实现,常用代理对象的类别为org.springframework.aop.framework.ProxyFactoryBean
 D.AOP可以在对目标(target)不做任何修改的情况下增加程序功能
 
  

5、下面关于spring描述错误的是:( )

A. Spring支持可插入的事务管理器,使事务划分更轻松,同时无需处理底层的问题。

B. Spring事务管理的通用抽象层还包括JTA策略和一个JDBC DataSource。

C. 与JTA或EJB CMT一样,Spring的事务支持依赖于Java EE环境。

D. Spring事务语义通过AOP应用于 POJO通过XML或Java SE 5注释进行配置。

6、下面选项哪个不是Spring中接口注入的方式?( )

A .接口注入  B .构造子注入  C .设值注入  D .指针注入

7、下列关于Spring特性中IoC描述错误的是:( )

A .IoC就是指程序之间的关系由程序代码直接操控。

B .所谓“控制反转”,是指控制权由应用代码转到外部容器,控制权的转移,

C.IoC将控制创建的职责搬进了框架中;并把它从应用代码脱离开来

D .当使用Spring的IoC容器时只需指出组件需要的对象,在运行时Spring的IoC容器会根据XML配置数据提供给它。

8、下列说法错误的是:()

A.Spring的 BeanFactory只能产生一个新的实例

B.Spring的 BeanFactory可以产生一个的实例

C.Spring的 BeanFactory可以产生两个的实例

D.Spring的 BeanFactory可以产生多个的实例

9、代理的方式的种类()

A.1种 B.2种 C.3种 D.4 种

10、pring的Advice类型有()

A.1种 B.2种 C.3种 D.4 种

二、简答题(每题5分 共50分)

1.描述一下Spring中实现DI(Dependency Injection)的几种方式

2. 简述你对IoC(Inversion of Control)的理解

3. Spring框架的优点都有什么?

4. Spring对多种ORM框架提供了很好的支持,简单描述在Spring中使用Hibernate的方法。

5. 如何在web应用里面配置spring?

6. spring中的BeanFactory与ApplicationContext的作用和区别?

8. 简述AOP核心?

9.Spring和Struts的区别?

10. 叙述Spring中的自动代理的原理?

三.论述题(每题15分 共30分)

1.什么是Spring, 使用Spring有什么好处?

2. 叙述一下SSH项目的执行过程:

一、选择题 (每题2分 共22分)

(1)一般情况下,关系数据模型与对象模型之间有哪些匹配关系(多选)

A)表对应类  B)记录对应对象  C)表的字段对应类的属性D)表之间的参考关系对应类之间的依赖关系

(2)以下关于SessionFactory的说法哪些正确?(多选)

A)对于每个数据库事务,应该创建一个SessionFactory对象B)一个SessionFactory对象对应一个数据库存储源。C)SessionFactory是重量级的对象,不应该随意创建。如果系统中只有一个数据库存储源,只需要创建一个。D)SessionFactory的load()方法用于加载持久化对象

(3)元素有一个cascade属性,如果希望Hibernate级联保存集合中的对象,casecade属性应该取什么值?(单选)

A)none B)save  C)delete  D)save-update

(4)以下哪些属于Session的方法?

A)load()B)save()C)delete()D)update()E)open()F)close()

(5)以下程序的打印结果是什么?(单选)

  1. tx = session.beginTransaction();
  2. Customer c1=(Customer)session.load(Customer.class,new Long(1));
  3. Customer c2=(Customer)session.load(Customer.class,new Long(1));
  4. System.out.println(c1==c2);
  5. tx.commit();
  6. session.close();

A)运行出错,抛出异常B)打印falseC)打印true

(6)以下程序代码对Customer的name属性修改了两次:

  1. tx = session.beginTransaction();
  2. Customer customer=(Customer)session.load(Customer.class,
  3. new Long(1));
  4. customer.setName(\”Jack\”);
  5. customer.setName(\”Mike\”);
  6. tx.commit();
  7. 执行以上程序,Hibernate需要向数据库提交几条update语句?(单选)

A)0  B)1 C)2  D)3

(7)在持久化层,对象分为哪些状态?(多选)

A)临时状态 B)独立状态 C)游离状态 D)持久化状态

(8)对于以下程序,Customer对象在第几行变为持久化状态?(单选)

  1. Customer customer=new Customer(); //line1
  2. customer.setName(\”Tom\”); //line2
  3. Session session1=sessionFactory.openSession(); //line3
  4. Transaction tx1 = session1.beginTransaction(); //line4
  5. session1.save(customer); //line4
  6. tx1.commit(); //line5
  7. session1.close(); //line6

A) line1 B)line2 C)line3 D)line4 E)line5 F)line6

(9)对于以下程序,Customer对象在第几行变为游离状态?(单选)

  1. Customer customer=new Customer(); //line1
  2. customer.setName(\”Tom\”); //line2
  3. Session session1=sessionFactory.openSession(); //line3
  4. Transaction tx1 = session1.beginTransaction(); //line4
  5. session1.save(customer); //line4
  6. tx1.commit(); //line5
  7. session1.close(); //line6

A) line1 B)line2 C)line3 D)line4 E)line5 F)line6

(10)关于HQL与SQL,以下哪些说法正确?(多选)

A)HQL与SQL没什么差别B)HQL面向对象,而SQL操纵关系数据库C)在HQL     

与SQL中,都包含select,insert,update,delete语句D)HQL仅用于查询数据,不支持insert,update和delete语句

(11)事务隔离级别是由谁实现的?(单选)

A)Java应用程序 B)Hibernate C)数据库系统 D)JDBC驱动程序

 

二、简答题(每题6分 共48分)

1.Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系)

2. Hibernate是如何延迟加载?

3. hibernate优点

4.简答Hibernate的缓存机制

5. Hibernate对象的三种状态是什么?

6.session.load()和session.get()的区别

7.如何优化Hibernate?

8. 在数据库中条件查询速度很慢的时候,如何优化?

三.论述题(每题15分 共30分)

1. Hibernate的主键生成机制

2. Hibernate工作原理及为什么要用?

原理:
1.读取并解析配置文件
2.读取并解析映射信息,创建SessionFactory
3.打开Sesssion
4.创建事务Transation
5.持久化操作
6.提交事务
7.关闭Session
8.关闭SesstionFactory

为什么要用:
1. 对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。
2. Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作
3. hibernate使用Java反射机制,而不是字节码增强程序来实现透明性。
4. hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。

2. Hibernate是如何延迟加载?
1. Hibernate2延迟加载实现:a)实体对象 b)集合(Collection)
2. Hibernate3 提供了属性的延迟加载功能;当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内存开销,从而提高了服务器的性能。
3.Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系)
类与类之间的关系主要体现在表与表之间的关系进行操作,它们都市对对象进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one、one-to-many、many-to-many、

4. 说下Hibernate的缓存机制
1. 内部缓存存在Hibernate中又叫一级缓存,属于应用事物级缓存
2. 二级缓存:
a) 应用及缓存
b) 分布式缓存
条件:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同一数据被系统频繁使用、非 关键数据
c) 第三方缓存的实现

5. Hibernate的查询方式
Sql、Criteria,object comptosition
Hql:
1、 属性查询
2、 参数查询、命名参数查询
3、 关联查询
4、 分页查询
5、 统计函数

6. 如何优化Hibernate?
1.使用双向一对多关联,不使用单向一对多
2.灵活使用单向一对多关联
3.不用一对一,用多对一取代
4.配置对象缓存,不使用集合缓存
5.一对多集合使用Bag,多对多集合使用Set
6. 继承类使用显式多态
7. 表字段要少,表关联不要怕多,有二级缓存撑腰

7. Struts工作机制?为什么要使用Struts?
工作机制:
Struts的工作流程:
在web应用启动时就会加载初始化ActionServlet,ActionServlet从
struts-config.xml文件中读取配置信息,把它们存放到各种配置对象
当ActionServlet接收到一个客户请求时,将执行如下流程.
-(1)检索和用户请求匹配的ActionMapping实例,如果不存在,就返回请求路径无效信息;
-(2)如果ActionForm实例不存在,就创建一个ActionForm对象,把客户提交的表单数据保存到ActionForm对象中;
-(3)根据配置信息决定是否需要表单验证.如果需要验证,就调用ActionForm的validate()方法;
-(4)如果ActionForm的validate()方法返回null或返回一个不包含ActionMessage的ActuibErrors对象, 就表示表单验证成功;
-(5)ActionServlet根据ActionMapping所包含的映射信息决定将请求转发给哪个Action,如果相应的 Action实例不存在,就先创建这个实例,然后调用Action的execute()方法;
-(6)Action的execute()方法返回一个ActionForward对象,ActionServlet在把客户请求转发给 ActionForward对象指向的JSP组件;
-(7)ActionForward对象指向JSP组件生成动态网页,返回给客户;

为什么要用:
JSP、Servlet、JavaBean技术的出现给我们构建强大的企业应用系统提供了可能。但用这些技术构建的系统非常的繁乱,所以在此之上,我们需要一个规则、一个把这些技术组织起来的规则,这就是框架,Struts便应运而生。
基于Struts开发的应用由3类组件构成:控制器组件、模型组件、视图组件

8. Struts的validate框架是如何验证的?
在struts配置文件中配置具体的错误提示,再在FormBean中的validate()方法具体调用。

9. 说下Struts的设计模式
MVC 模式: web应用程序启动时就会加载并初始化ActionServler。用户提交表单时,一个配置好的ActionForm对象被创建,并被填入表单相应的数据,ActionServler根据Struts-config.xml文件配置好的设置决定是否需要表单验证,如果需要就调用ActionForm的 Validate()验证后选择将请求发送到哪个Action,如果Action不存在,ActionServlet会先创建这个对象,然后调用 Action的execute()方法。Execute()从ActionForm对象中获取数据,完成业务逻辑,返回一个ActionForward对象,ActionServlet再把客户请求转发给ActionForward对象指定的jsp组件,ActionForward对象指定的jsp生成动态的网页,返回给客户。

10. spring工作机制及为什么要用?
1.spring mvc请所有的请求都提交给DispatcherServlet,它会委托应用系统的其他模块负责负责对请求进行真正的处理工作。
2.DispatcherServlet查询一个或多个HandlerMapping,找到处理请求的Controller.
3.DispatcherServlet请请求提交到目标Controller
4.Controller进行业务逻辑处理后,会返回一个ModelAndView
5.Dispathcher查询一个或多个ViewResolver视图解析器,找到ModelAndView对象指定的视图对象
6.视图对象负责渲染返回给客户端。

为什么用:
{AOP 让开发人员可以创建非行为性的关注点,称为横切关注点,并将它们插入到应用程序代码中。使用 AOP 后,公共服务 (比 如日志、持久性、事务等)就可以分解成方面并应用到域对象上,同时不会增加域对象的对象模型的复杂性。
IOC 允许创建一个可以构造对象的应用环境,然后向这些对象传递它们的协作对象。正如单词 倒置 所表明的,IOC 就像反 过来的 JNDI。没有使用一堆抽象工厂、服务定位器、单元素(singleton)和直接构造(straight construction),每一个对象都是用其协作对象构造的。因此是由容器管理协作对象(collaborator)。
Spring即使一个AOP框架,也是一IOC容器。 Spring 最好的地方是它有助于您替换对象。有了 Spring,只要用 JavaBean 属性和配置文件加入依赖性(协作对象)。然后可以很容易地在需要时替换具有类似接口的协作对象。}

 

你可能感兴趣的:(SSH面试题)