原创: 阿木侠
1,谈谈你对Struts的理解。
1. struts是一个按MVC模式设计的Web层框架,实在它便是一个Servlet,这个Servlet名为ActionServlet,或是ActionServlet的子类。我们可以在web.xml文件中将符合某种特色的所有要求交给这个Servlet处理,这个Servlet再参照一个配置文件将各个要求分别分配给不同的action去处理。
(struts的配置文件可以有多个,可以按模块配置各自的配置文件,这样可以防止配置文件的过度膨胀)
2.ActionServlet把要求交给action去处理之前,会将要求参数封装成一个formbean工具(便是一个java类,这个类中的每个属性对应一个要求参数),
3.要解释的是, ActionServlet把formbean工具通报给action的execute方法之前,可能会调用formbean的validate方法进行校验,只有校验通过后才将这个formbean工具通报给action的execute方法,否则,它将返回一个缺点页面,这个缺点页面由input属性指定。
4.action实行完后要返回显示的结果视图,这个结果视图是用一个ActionForward工具来表示的,actionForward工具通过struts-config.xml配置文件中的配置关联到某个jsp页面,由于程序中利用的是在struts-config.xml配置文件为jsp页面设置的逻辑名,这样可以实现action程序代码与返回的jsp页面名称的解耦。
(以上,也可以结合自己利用感想熏染谈自己的意见)
2、谈谈你对Hibernate的理解。
1. 面向工具设计的软件内部运行过程可以理解造诣是在不断创建各种新工具、建立工具之间的关系,调用工具的方法来改变各个工具的状态和工具消亡的过程,不管程序运行的过程和操作怎么样,实质上都是要得到一个结果,程序上一个时候和下一个时候的运行结果的差异就表现在内存中的工具状态发生了变革。
2.为了在关机和内存空间不足的状况下,保持程序的运行状态,须要将内存中的工具状态保存到持久扮装备和从持久扮装备中规复出工具的状态,常日都是保存到关系数据库来保存大量工具信息。从Java程序的运行功能上来讲,保存工具状态的功能比较系统运行的其他功能来说,该当是一个很不起眼的附属功能,java采取jdbc来实现这个功能,这个不起眼的功能却要编写大量的代码,而做的事情仅仅是保存工具和规复工具,并且那些大量的jdbc代码并没有什么技能含量,基本上是采取一套例行公事的标准代码模板来编写,是一种苦活和重复性的事情。
3.通过数据库保存java程序运行时产生的工具和规复工具,实在便是实现了java工具与关系数据库记录的映射关系,称为ORM(即Object RelationMapping),人们可以通过封装JDBC代码来实现了这种功能,封装出来的产品称之为ORM框架,Hibernate便是个中的一种盛行ORM框架。利用Hibernate框架,不用写JDBC代码,仅仅是调用一个save方法,就可以将工具保存到关系数据库中,仅仅是调用一个get方法,就可以从数据库中加载出一个工具。
4.利用Hibernate的基本流程是:配置Configuration工具、产生SessionFactory、创建session工具,启动事务,完成CRUD操作,提交事务,关闭session。
5.利用Hibernate时,先要配置hibernate.cfg.xml文件,个中配置数据库连接信息和方言等,还要为每个实体配置相应的hbm.xml文件,hibernate.cfg.xml文件中须要登记每个hbm.xml文件。
6.在运用Hibernate时,重点要理解Session的缓存事理,级联,延迟加载和hql查询。
(以上,也可以结合自己利用JDBC时的繁琐谈hibernate的感想熏染)
3,谈谈你对Spring的理解。
1.Spring是实现了工厂模式的工厂类(在这里有必要阐明清楚什么是工厂模式),这个类名为BeanFactory(实际上是一个接口),在程序中常日BeanFactory的子类ApplicationContext。Spring相称于一个大的工厂类,在其配置文件中通过<bean>元素配置用于创建实例工具的类名和实例工具的属性。
2. Spring供应了对IOC良好支持,IOC是一种编程思想,是一种架构艺术,利用这种思想可以很好地实现模块之间的解耦,IOC也称为DI(Depency Injection)。
3. Spring供应了对AOP技能的良好封装, AOP称为面向切面编程,便是系统中有很多各不相关的类的方法,在这些浩瀚方法中要加入某种系统功能的代码,例如,加入日志,加入权限判断,加入非常处理,这种运用称为AOP。
实现AOP功能采取的是代理技能,客户端程序不再调用目标,而调用代理类,代理类与目标类对外具有相同的方法声明,有两种办法可以实现相同的方法声明,一是实现相同的接口,二是作为目标的子类。
在JDK中采取Proxy类产生动态代理的办法为某个接口天生实现类,如果要为某个类天生子类,则可以用CGLI B。在天生的代理类的方法中加入系统功能和调用目标类的相应方法,系统功能的代理以Advice工具进行供应,显然要创建出代理工具,至少须要目标类和Advice类。spring供应了这种支持,只须要在spring配置文件中配置这两个元素即可实现代理和aop功能。
(以上,也可以结合自己利用感想熏染谈自己的意见)
4,谈谈Struts的优缺陷
优点:
1. 实现MVC模式,构造清晰,使开拓者只关注业务逻辑的实现.
2.有丰富的tag可以用 ,Struts的标记库(Taglib),如能灵巧动用,则能大大提高开拓效率
3. 页面导航使系统的脉络更加清晰。通过一个配置文件,即可把握全体系统各部分之间的联系,这对付后期的掩护有着莫大的好处。尤其是当另一批开拓者接手这个项目时,这种上风表示得更加明显。
4. 供应Exception处理机制 .
5. 数据库链接池管理
6. 支持I18N
缺陷:
一,转到展示层时,须要配置forward,如果有十个展示层的jsp,须要配置十次struts,而且还不包括有时候目录、文件变更,须要重新修正forward,把稳,每次修正配置之后,哀求重新支配全体项目,而tomcate这样的做事器,还必须重新启动做事器
二,Struts的Action必需是thread-safe办法,它仅仅许可一个实例去处理所有的要求。以是action用到的所有的资源都必需统一同步,这个就引起了线程安全的问题。
三,测试未便利. Struts的每个Action都同Web层耦合在一起,这样它的测试依赖于Web容器,单元测试也很难实现。不过有一个Junit的扩展工具Struts TestCase可以实现它的单元测试。
四,类型的转换. Struts的FormBean把所有的数据都作为String类型,它可以利用工具Commons-Beanutils进行类型转化。但它的转化都是在Class级别,而且转化的类型是不可配置的。类型转化时的缺点信息返回给用户也是非常困难的。
五,对Servlet的依赖性过强. Struts处理Action时必需要依赖ServletRequest和ServletResponse,所有它摆脱不了Servlet容器。
六,前端表达式措辞方面.Struts集成了JSTL,以是它紧张利用JSTL的表达式措辞来获取数据。可是JSTL的表达式措辞在Collection和索引属性方面处理显得很弱。
七,对Action实行的掌握困难. Struts创建一个Action,如果想掌握它的实行顺序将会非常困难。乃至你要重新去写Servlet来实现你的这个功能需求。
八,对Action实行前和后的处理. Struts处理Action的时候是基于class的hierarchies,很难在action处理前和后进行操作。
九,对事宜支持不足.在struts中,实际是一个表单Form对应一个Action类(或DispatchAction),换一句话说:在Struts中实际是一个表单只能对应一个事宜,struts这种事宜办法称为application event,application event和component event比较是一种粗粒度的事宜
5,iBatis与Hibernate有什么不同?
相同点:屏蔽jdbc api的底层访问细节,利用我们不用与jdbc api打交道,就可以访问数据。
jdbc api编程流程固定,还将sql语句与java代码殽杂在了一起,常常须要拼凑sql语句,细节很繁琐。
ibatis的好处:屏蔽jdbc api的底层访问细节;将sql语句与java代码进行分离;供应了将结果集自动封装称为实体工具和工具的凑集的功能,queryForList返回工具凑集,用queryForObject返回单个工具;供应了自动将实体工具的属性通报给sql语句的参数。
Hibernate是一个全自动的orm映射工具,它可以自动天生sql语句,ibatis须要我们自己在xml配置文件中写sql语句,hibernate要比ibatis功能卖力和强大很多。由于hibernate自动天生sql语句,我们无法掌握该语句,我们就无法去写特定的高效率的sql。对付一些不太繁芜的sql查询,hibernate可以很好帮我们完成,但是,对付特殊繁芜的查询,hibernate就很难适应了,这时候用ibatis便是不错的选择,由于ibatis还是由我们自己写sql语句。
6,在hibernate进行多表查询每个表中各取几个字段,也便是说查询出来的结果集没有一个实体类与之对应如何办理?
办理方案一,:按照Object[]数据取出数据,然后自己组bean
办理方案二:对每个表的bean写布局函数,比如表一要查出field1,field2两个字段,那么有一个布局函数便是Bean(type1filed1,type2
field2) ,然后在hql里面就可以直接天生这个bean了。
7,先容一下Hibernate的二级缓存
按照以下思路来回答:
(1)首先说清楚什么是缓存
(2)再说有了hibernate的Session便是一级缓存,即有了一级缓存,为什么还要有二级缓存
(3)末了再说如何配置Hibernate的二级缓存。
1,缓存便是把以前从数据库中查询出来和利用过的工具保存在内存中(一个数据构造中),这个数据构造常日是或类似HashMap,当往后要利用某个工具时,先查询缓存中是否有这个工具,如果有则利用缓存中的工具,如果没有则去查询数据库,并将查询出来的工具保存在缓存中,以便下次利用。
2,Hibernate的Session便是一种缓存,我们常日将之称为Hibernate的一级缓存,当想利用session从数据库中查询出一个工具时,Session也是先从自己内部查看是否存在这个工具,存在则直接返回,不存在才去访问数据库,并将查询的结果保存在自己内部。
由于Session代表一次会话过程,一个Session与一个数据库连接干系连,以是Session最好不要永劫光保持打开,常日仅用于一个事务当中,在事务结束时就应关闭。并且Session是线程不屈安的,被多个线程共享时随意马虎涌现问题。常日只有那种全局意义上的缓存才是真正的缓存运用,才有较大的缓存代价,因此,Hibernate的Session这一级缓存的缓存浸染并不明显,运用代价不大。Hibernate的二级缓存便是要为Hibernate配置一种全局缓存,让多个线程和多个事务都可以共享这个缓存。我们希望的是一个人利用过,其他人也可以利用,session没有这种效果。
3,二级缓存是独立于Hibernate的软件部件,属于第三方的产品,多个厂商和组织都供应有缓存产品,例如,EHCache和OSCache等等。在Hibernate中利用二级缓存,首先就要在hibernate.cfg.xml配置文件中配置利用哪个厂家的缓存产品,接着须要配置该缓存产品自己的配置文件,末了要配置Hibernate中的哪些实体工具要纳入到二级缓存的管理中。明白了二级缓存事理和有了这个思路后,很随意马虎配置起Hibernate的二级缓存。
扩展知识:一个SessionFactory可以关联一个二级缓存,也即一个二级缓存只能卖力缓存一个数据库中的数据,当利用Hibernate的二级缓存后,把稳不要有其他的运用或SessionFactory来变动当前数据库中的数据,这样缓存的数据就会与数据库中的实际数据不一致。
8,JDO是什么?
JDO是Java工具持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的工具的标准化API。JDO供应了透明的工具存储,因此对开拓职员来说,存储数据工具完备不须要额外的代码(如JDBC API的利用)。这些繁琐的例行事情已经转移到JDO产品供应商身上,使开拓职员解脱出来,从而集中韶光和精力在业务逻辑上。其余,JDO很灵巧,由于它可以在任何数据底层上运行。
比较:JDBC只是面向关系数据库(RDBMS)JDO更通用,供应到任何数据底层的存储功能,比如关系数据库、文件、XML以及工具数据库(ODBMS)等等,使得运用可移植性更强。
9,Hibernate的一对多和多对一双向关联的差异??
一对多关联映射和多对一关联映射实现的基本事理都是一样的,既是在多的一端加入一个外键指向一的一端外键,而紧张的差异便是掩护端不同。
它们的差异在于掩护的关系不同:
一对多关联映射是指在加载一的一端数据的同时加载多的一真个数据多对一关联映射是指在加载多的一端数据的同时加载一的一真个数据。
10,Hibernate是如何延迟加载?
1. Hibernate2延迟加载实现:a)实体工具 b)凑集(Collection)
2. Hibernate3 供应了属性的延迟加载功能 当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,工具才存在与内存中,就实现了延迟加载,他节省了做事器的内存开销,从而提高了做事器的性能。