Q:Hibernate工作原理及为什么要用?
A:原理:
1 读取并解析配置文件
2 读取并解析映射文件,创建SessionFactory
3 打开Session
4 创建事务Transation
5 持久化操作
6 提交事务
7 关闭Session
8 关闭SessionFactory
为什么要用:
* 对JDBC访问数据库的代码做了封装,大大简化了数据库访问层繁琐的重复性代码。
* Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作
* Hibernate使用java反射机制,而不是字节码增强程序来实现透明性。
* Hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。
Q:Hibernate是如何延迟加载?
A:*Hibernate2延迟加载实现: a)实体对象 b)集合(Collection)
* Hibernate3提供了属性的延迟加载功能
当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内存开销,从而提高了服务器的性能。
Q:Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系)
A:类与类之间的关系主要体现在表与表之间的关系进行操作,它们都是对对象进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one,one-to-many,many-to-many
Q:说下Hibernate的缓存机制
A:*内部缓存在Hibernate中又叫一级缓存,属于应有事务级缓存
* 二级缓存:
a)应用及缓存
b)分布式缓存
条件:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同一数据被系统频繁使用、非键数据
c)第三方缓存的实现
Q:Hibernate的查询方式
A:Sql,Criteria,object comptosition
Hql:
*属性查询
*参数查询、命名参数查询
*关联查询
*分页查询
*统计函数
Q:如何优化Hibernate?
A:*使用双向一对多关联,不使用单向一对多
*灵活使用单向一对多关联
*不用一对一,用多对一取代
*配置对象缓存,不使用集合缓存
*一对多集合使用bag,多对多集合使用set
*继承类使用显式多态
*表字段要少,表关联不要怕多,有二级缓存撑
Q:Struts工作机制?为什么要使用Struts?
A:工作机制:
Struts的工作流程
在web应用启动时就会加载初始化ActionServlet,ActionServlet从struts-config.xml文件中读取配置信息,把它们存放到各种配置对象当ActionServlet接受到一个客户请求时,将执行如下流程:
(1)检索和用户请求匹配的ActionMapping实例,如果不存在,就返回请求路径无效信息。
(2)如果ActionForm实例不存在,就创建一个ActionForm对象,把客户提交的表单数据保存到ActionForm对象中;
(3)根据配置信息决定是否需要表单验证,如果需要验证,就调用ActionForm的validate()方法;
(4)如果ActionForm的validate()方法返回null或返回一个不包含ActionMessage的ActionErrors对象,就表示表单验证成功;
(5)ActionServlet根据ActionMapping所包含的映射信息决定将请求转发给哪个Action,如果相应的Action实例不存在,就先创建这个实例,然后调用Action的execute()方法;
(6)Action的execute()方法返回一个ActionForward对象,ActionServlet在把客户请求转发给ActionForward对象指向的JSP组件
(7)ActionForward对戏哪个指向JSP组件生成动态网页,返回给客户。
为什么要用:
JSP,Servlet,JavaBean技术的出现给我们构建强大的企业应用系统提供了可能。但用这些技术构建的系统非常的繁乱,所以在此之上,我们需要一个规则、一个把这些技术组织起来的规则,这就是框架,Struts应运而而生。
基于Struts开发的应有由3类组件构成:控制器组件、模型组件、视图组件
Q:Struts的validate框架是如何验证的?
A:在Struts配置文件中配置具体的错误提示,再在FormBean中的validate()方法具体调用。
Q:说下Struts的设计模式
A:MVC模式:web应用程序启动时就会加载并初始化ActionServlet。用户提交表单时,一个配置好的ActionForm对象被创建,并被填入表单相应的数据,ActionServlet根据Struts-config.xml文件配置好的设置决定是否需要表单验证,如果需要就调用ActionForm的Validate()验证后选择将请求发送到哪个Action,如果Action不存在,ActionServlet会先创建这个对象,然后调用Action的execute()方法。Execute()从ActionForm对象中获取数据,完成业务逻辑,返回一个ActionForward对象,ActionServlet再把客户请求转发给ActionForward对象指定的JSP组件,ActionForward对象指定的jsp生成动态的网页,返回给客户。
单例模式Factory(工程模式):
定义一个基类-〉实现基类方法(子类通过不同的方法)-〉定义一个工厂类(生成子类实例)-〉开发人员调用基类方法
Proxy(代理模式)
Q:spring工作机制及为什么要用?
A:1 spring mvc请所有的请求都提交给DispatcherServlet,它会委托应用系统的其他模块负责对请求进行真正的处理工作。
3 DispatcherSevlet请求提交到目标Controller
4 Controller进行业务逻辑处理后,会返回一个ModelAndView.
5 Dispathcher查询一个或对个ViewResolver视图解析器,找到ModelAndView对象指定的视图对象
6 视图对象负责渲染返回给客户端。
为什么要用:
AOP让开发人员可以创建非行为性的关注点,称为横切关注点,并将它们插入到应用程序代码中。使用AOP后,公共服务(比如日志、持久性、事务等)就可以分解成方面并应用到域对象上,同时不会增加域对象的对象模型的复杂性。
IOC允许创建一个可以构造对象的应用环境,然后向这些对象传递它们的协作对象。正如单词倒置所表明的,IOC就像反过来的JNDI。没有使用一堆抽象工厂、服务定位器、单元素(singleton)和直接构造(straight contruction),每一个对象都是用其协作对象构造的。因此是由容器管理协作对象(collaborator).
Spring既是一个AOP框架,也是一个IOC容器。Spring最好的地方是它有助于您替换对象。有了Spring,只要用JavaBean属性和配置文件加入依赖性(协作对象)。然后可以很容易地在需要时替换具有类似借口的协作对象。