Struts,Hibernate,Spring经典面试题

在开发中主要分为三个层次,表现层,服务层,持久层。从这三层去解耦。

Spring的作用就是把服务从表现层中,抽取出来;

Hibernate把持久层抽取出来; 

剩下的表现层交给Struts控制。

 

Hibernate工作原理:

①读取并解析配置文件

②读取并解析映射信息,创建SessionFactory

③打开Session

④创建事物Transaction

⑤持久化操作

⑥提交事务

⑦关闭Session

⑧关闭SessionFaction

为什么要用:

①对JDBC访问数据库的代码做了封装,大大简化了数据访问繁琐的重复性代码;

②Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM 实现。他很大程度的简化DAO层的编码工作

③Hibernate使用Java反射机制,而不是字节码增强程序来实现透明性。

④Hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系的数据库,从一对一到多对多的各种复杂关系。

Hibernate是如何实现延迟加载:

①hibernate2延迟加载实现:a)实体对象  b)集合(Collection)

②hibernate3提供了属性的延迟加载功能

当Hibernate在查询数据的时候,数据并没有存在于内存中,当程序真正对数据的操作时,对象才存在于内存中,就实现了延迟加载,它节省了服务器的内存开销,从而提高了服务器的性能。

Hibernate中怎样实现类之间的关系:

类与类之间的关系主要体现在表与表之间的关系进行操作,他们都是对对象进行操作,我们程序中把所有的表与类都映射在一起,他们通过配置文件中的many-to-one、one-to-many、many-to-many。

说下Hibernate的缓存机制

①内部缓存存在Hibernate中又叫一级缓存,属于应用事物及缓存

②二级缓存

a)应用级缓存

b)分布式缓存

条件:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同一数据被系统频繁使用、非关键数据。

c)第三方缓存的实现

Hibernate 的查询方式:

1、属性查询

2、参数查询、命名参数查询

3、关联查询

4、分页查询

5、统计查询

如何优化Hibernate:

1、使用双向一对多的关联,不适用单向一对多

2、灵活使用单向一对多关联

3、不用一对一,用多对一取待

4、配置对象缓存,不适用集合缓存

5、一对多集合使用Bag,多对多集合使用Set

6、继承类使用显示多态

7、表字段要少,表关联不要怕多,有二级缓存撑腰。

Struts工作机制?

①. 请求发送给 StrutsPrepareAndExecuteFilter

②. StrutsPrepareAndExecuteFilter 判定该请求是否是一个 Struts2 请 求

③. 若该请求是一个 Struts2 请求,则 StrutsPrepareAndExecuteFilter 把请求的处理交给 ActionProxy

④. ActionProxy 创建一个 ActionInvocation 的实例,并进行初始化

⑤. ActionInvocation 实例在调用 Action 的过程前后,涉及到相关拦截 器(Intercepter)的调用。

⑥. Action 执行完毕,ActionInvocation 负责根据 struts.xml 中的配置 找到对应的返回结果。调用结果的 execute 方法,渲染结果。

⑦. 执行各个拦截器 invocation.invoke() 之后的代码

⑧. 把结果发送到客户端

为什么使用Struts?

JSP、Servlet、JavaBean技术的出现给我们构建强大的企业应用 z系统提供了可能。但用这些技术构建的系统非常的繁乱,所以在此之上,我们需要一个规则、一个把这些技术组织起来的规则,这就是框架,Struts变应运而生。

 

基于Struts开发的应用由3类组件构成:控制器组件、模型组件、视图组件。

Struts的validate框架是如何验证的?配置为恩建中配置具体的错误提示,再在FormBean中的validate()方法具体调用。

在struts

 

posted @ 2017-07-24 01:36  被爱的都有恃无恐  阅读(178)  评论(0编辑  收藏  举报