Java是学软件技术方面的一门必不可少的语言,框架更是重中之重,每年面试,只要我们是学这个的,只要我们面的是这个方面的,那往往框架问题都是必问的点。所以下面我写了些框架方面的点,写的有些乱,大家别介意。
但是我这里有整理好的Java方面的知识点的文档和PDF,有需要的可以点击进入暗号:cszq
Spring mvc运行原理:
DispatcherServlet主要用作职责调度工作,本身主要用于控制流程
(1)客户端请求提交到DispatcherServlet;
(1)由DispatcherServlet控制器查询一个或多HandlerMapping,找到处理请求的Controller;
(3)DispatcherServlet将请求提交到Controller;
(4)Controller调用业务逻辑处理后,返回ModelAndView;
(5)DispatcherServlet查询一个或多个ViewResoler视图解析器,找到ModelAndView指定的视图;
(6)视图负责将结果显示到客户端。
DispatcherServlet是整个Spring MVC的核心。它负责接收HTTP请求组织协调Spring MVC的各个组成部分。其主要工作有以下三项:
(1)截获符合特定格式的URL请求;
(2)初始化DispatcherServlet上下文对应的WebApplicationContext,并将其与业务层、持久化层的WebApplicationContext建立关联;
(3)初始化Spring MVC的各个组成组件,并装配到DispatcherServlet中。
注解:
DispatcherServlet:前端控制器(相当于一个转发器,中央处理器,调度)。
ModelAndView:模型和视图的结合体(Spring mvc的底层对象)。
HandlerMapping: 处理器映射器。
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的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。
Struts工作机制?为什么要使用Struts?
工作机制:
Struts的工作流程:
在web应用启动时就会加载初始化ActionServlet,ActionServlet从struts-config.xml文件中读取配置信息,把它们存放到各种配置对象当ActionServlet接收到一个客户请求时,将执行如下流程:
(1)检索和用户请求匹配的Action Mapping实例,如果不存在,就返 回请求路径无效信息;
(2)如果Action Form实例不存在,就创建一个Action Form对象,把客户提交的表单数据保存到Action Form对象中;
(3)根据配置信息决定是否需要表单验证.如果需要验证,就调用Action Form的validate()方法;
(4)如果Action Form的validate()方法返回null或返回一个不包含Action Message的 ActuibErrors对象,就表示表单验证成功;
(5)Action Servlet 根据Action Mapping所包含的映射信息决定将请求转发给哪个Action,如果相应的Action实例不存在,就先创建这个实例,然后调用Action的execute()方法;
(6)Action的execute()方法返回一个Action Forward对,象,Action Servlet在把客户请求转发给 Action Forward对象指向的JSP组件;
(7)Action Forward对象指向JSP组件生成动态网页,返回给客户。
为什么要用:
JSP、Servlet,JavaBean技术的出现给我们构建强大的企业应用系统提供了可能。但用这些技术构建的系统非常的繁乱,所以在此之上,我们需要一个规则、一个把这些技术组织起来的规则,这就是框架,Struts便应运而生。
注解·:
基于Struts开发的应用由3类组件构成:控制器组件、模型组件、视图组件。
如何优化Hibernate?
(1)使用双向一对多关联,不使用单向一对多
(2)灵活使用单向一对多关联
(3)不用一对一,用多对一取代
(4)配置对象缓存,不使用集合缓存
(5)一对多集合使用Bag,多对多集合使用Set
(6)继承类使用显式多态
(7)&表字段要少,表关联不要怕多,有二级缓存撑腰