• SSH框架面试总结----1


    1:struts2的工作流程

      1)客户端浏览器发出HTTP请求。

      2)根据web.xml配置,HTTP请求会被FilterDispatcher接收。

      3)根据struts.xml,找到对应的Action类和方法,并通过IOC方式,注入参数给Action。

      4)Action调用业务逻辑组件处理业务逻辑。

      5)Action执行完后,通过struts2.xml配置找到返回结果result,并跳转到对应页面。

      6)返回HTTP响应到客户端浏览器。

    2:spring的优点

      1:低侵入式设计,代码污染率极低。

      2:独立于各种应用服务器,基于spring框架实现了一次编写,处处运行。

      3:DI机制降低了业务对象替换的复杂性,提高了程序之间的解耦。

      4:AOP支持允行将通用任务如安全、事务、日志等集中管理,从而提高更好的复用。

      5:Spring的ORM和dao提供了第三方持久层框架的良好整合,并简化了底层数据库的访问.

      6:灵活的设计模式和对各种框架的集成

    3:spring事务的几种方式

      1)编程式事务管理:需要手动编写代码。

      2)基于TransactionProxyFactoryBean声明式事务管理:需要为每个进行事务管理的类做相应的配置

      3)基于AspectJ的XML的声明式事务管理,不需要改动类,在XML文件中配置即可

      4)基于注解的声明式事务管理,配置简单,需要在业务层类中添加注解

    4:spring事务特性

      什么是事务:事务逻辑上的一组操作,组成这组操作的各个逻辑单元,要么一起成功,要么一起失败。

      4种事务特性:原子性:一个事务中对数据库的操作是不可分割的操作序列,要么完全执行完,要么所有执行失败。

              一致性:数据不会因为事务的执行而遭到破坏。

              隔离性:一个事务在执行过程中不会受到其它事务的影响。

              持久性:一个事务的提交是对数据的改变是永久的。

    5:事务的隔离级别

      DEFAULT:使用数据库的默认隔离级别

      read nocommited:未提交读,是最低的事务隔离级别,它充许一个事务可以看到另一个事务未提交的数据,可能导致脏度、不可重复度、幻读。

      read commited :已提交读,只有一个事务提交后另一个事务才能读取第一个事务提交的数据。避免了脏读,可能导致不可重复读、幻读。

      repeatable read:避免了脏读、不可重复读,但有可能导致幻读。

      serializable:避免了脏读、不可重复读、幻读,是一种最可靠的事务隔离级别,但花费的代价也是最高的。

    6:什么是脏读,不可重复读,幻读。

      1)脏读:指当一个事务对数据进行了修改,但没有提交,这时另一个事务对这个数据读取操作,但由于修改后的数据没有提交,所以导致事务2的数据是错误的。

      2)不可重复读:事务1读取一个数据后,事务1还没有结束,这时事务2修改了数据,之后事务1又重新读取数据,导致两次读取的数据不同。

      3)幻读:事务1对表中的一行数据或者一列数据全部进行了修改,而这时事务2又插入了一条数据,导致用户以为数据表中的数据没有被修改,就好像产生幻觉了。

    7:mybatis与Hibernate有什么不同?

      相同点:屏蔽jdbc api底层访问细节,使我们不用和jdbc api打交道就可以访问数据库。

      不同点:mybatis将sql语名与java代码分离,提供了将结果集自动封装为实体对象和对象集合的功能,提供了自动将实体对象的属性传递给sql语名的参数。它是通过xml配置文件中写sql语句。

          Hibernate:它是一个全自动的orm映射工具,它可以自动生成sql语句,对于一些不太复杂的sql查询,hibernate可以很好帮我们完成。

    8:Hibernate的缓存机制

      为什么要有缓存:它是一个待久层框架,它需要经常访问数据库,为了降低应用程序对物理数据的访问频率,从而提高应用程序的运行效率。

      缓存分类:

        一级缓存:Hibernate一级缓存是保存在session中的,其生命周期也和session一样,当查询数据的时候,首先会查询session里面是否有当前所需要的数据,如果没有,它会将查询的数据保存在session中,下次查询这条数据的时候会直接在session中查询。

        二级缓存:二级缓存又叫SessionFactory缓存。Hibernate的二级缓存就是要为Hibernate配置一种全局缓存,让多个线程和多个事务都可以共享这个缓存。它可以在多个session中共享缓存中的数据。它主要保存很少被修改、不会被并发访问、不是很重要的数据。

      当要访问数据时,首先会先访问Session中是否有数据,如没有也配置了二级缓存,然后会在SessionFactory中查询,如果也没有才会去数据库里查询数据。在执行删除、更新、添加操作时,同时也会更新缓存。

    9:Session和cookie有什么区别

      Cookie是会话技术,将用户的信息保存到浏览器的对象,也就是保存在本地计算机中。Session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息,数据也是保存在服务器上的。

      区别:

        1:cookie数据是存放在客户端浏览器上的,Session数据是存放在服务器上的。

        2:对于比较重要的数据应存放在Session中,因为cookie是不安全的,别人可以通过分析cookie进行cookie欺骗。

        3:Session会在其生命周期内何存在服务器上,当访问增多会影响服务器的性能。如只考虑服务器性能,尽量将数据保存在cookies中。

        4:单个cookie中保存的数据不能超过4K

        5:将登录信息保存在Session中,其它不重要的信息尽量保存在cookies中。

    10:如何优化Hibernate

       1:使用双向一对多关联,不使用单向一对多

       2:灵活使用单向一对多

       3:不用一对一,用多对一取代

       4:配置对象缓存,不使用集合缓存

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

       6:继承类使用显示多态

       7:表字段要少,多使用表关联

  • 相关阅读:
    jenkins 使用oclint 扫描 oc 代码
    mac下 jenkins 环境搭建
    jenkins 中 Poll SCM 和 Build periodically 的区别
    表单验证封装,一招学会,永远受用
    浅谈js中的执行环境和执行环境对象
    浅谈php之设计模式基础
    四条地铁线带你通往Ajax的大门
    论js结合数学的应用
    以留言本的开发打开ajax的世界
    初步学习css3之3D动画
  • 原文地址:https://www.cnblogs.com/EmilZs/p/9236588.html
Copyright © 2020-2023  润新知