首页 软通动力面试题集

软通动力面试题集

举报
开通vip

软通动力面试题集.实用文档..Struts的运行机制:Web应用初始化时,控制器加载分析配置文件〔struts-config.xml〕,获得ActionMapping,配置应用程序ActionServlet接收用户请求ActionServlet根据应用程序配置填充ActionFormActionServlet根据ActionMapping调用Action的execute方法Action调用业务逻辑类〔Model〕,在简单的程序中也可以在Action的execute方法中执行业务处理业务逻辑类将处理结果返回给Action,Actio...

软通动力面试题集
.实用文档..Struts的运行机制:Web应用初始化时,控制器加载分析配置文件〔struts-config.xml〕,获得ActionMapping,配置应用程序ActionServlet接收用户请求ActionServlet根据应用程序配置填充ActionFormActionServlet根据ActionMapping调用Action的execute方法Action调用业务逻辑类〔Model〕,在简单的程序中也可以在Action的execute方法中执行业务处理业务逻辑类将处理结果返回给Action,Action将处理结果保存在适当的作用域范围之内〔session、request等〕Action的execute方法向ActionServlet返回ActionForward指明下一步调用的Action或JSP视图JSP视图取得保存在作用域之中的业务处理结果并负责显示HTML页面大家最好用自己的话来总结出来!常用的集合以及介绍:〔应重点复习〕常用集合set、map、listset、map是collection接口的子接口set接口的实现类:HashSet、TreeSetList接口的实现类:ArrayList、linkedListMap接口的实现类:HashMap、TreeMap、Hashtable。ArrayList和linkedList的区别(略)HashMap、HashTable区别(略)遍历map的方法:使用Map接口提供的方法entrySet();importjava.util.HashMap;importjava.util.Iterator;importjava.util.Map;publicclassMapTest{publicstaticvoidmain(String[]args){Mapmap=newHashMap();map.put("a","中国");map.put("b","ABC");map.put("c",1000);/*for(Iterator>it=map.entrySet().iterator();it.hasNext();){Entryentry=it.next();System.out.println(entry);System.out.println(entry.getKey());System.out.println(entry.getValue());}*/for(Iteratorit=map.keySet().iterator();it.hasNext();){Objectkey=it.next();System.out.println(key);Objectvalue=map.get(key);System.out.println(value);}}}4.字符串相加用“+〞和append()的区别用“+“号每加一次创立一个对象,比方:字符串常量池中有原字符串:〞abc〞之后要加〞de〞,加过之后内存中会有〞abc〞、〞abcde〞两个字符串!但〞abc〞会失去原本指向它的引用变成垃圾回收机制回收的对象!Append()只是将字符串追加到原字符串的尾部,始终都是一个对象!垃圾回收机制原理:当一个对象赋值为null或者没有指引指向他的时候,那么这个对象就符合垃圾回收机制回收的范围,java虚拟时机不定时的对垃圾进行回收,回收对象之前会调用被回收对象的finalize()方法!注意Java虚拟机何时来回收垃圾不确定!如何实现多线程:继承Thread类或者实现Runnable接口那种好处多:因为java是单继承所以一般会采用实现Runnable接口两种实现方式的区别:继承Thread类可以创立本类对象直接调用start()方法运行线程〔也就是说本类对象就是一个线程个人理解〕实现Runnable接口必须用Threadthread=newThread()来获得一个线程!7.代码的重构:代码的输入、输出不变,只是改变中间实现代码!8.MVC思想是model、view、controller的缩写,model代表业务逻辑(通过javabean、EJB组建实现)、view是应用表示面(由jsp页面产生)、controller是提供给用处理过程的控制(一般是一个servlet)。通过这种 设计 领导形象设计圆作业设计ao工艺污水处理厂设计附属工程施工组织设计清扫机器人结构设计 模式把应用逻辑、处理过程、显示逻辑分成不同的组件实现,可提高组件的交互和重用性。9.struts1和struts2的区别〔见最后一页〕10:讲解一下Spring11:hibernate是怎么工作的原理:1.读取并解析配置文件2.读取并解析映射信息,创立SessionFactory3.翻开Sesssion4.创立事务Transation5.持久化操作6.提交事务7.关闭Session8.关闭SesstionFactory12:hibernate的一级和二级缓存是什么Hibernate提供了两级缓存,第一级是Session的缓存。由于Session对象的生命周期通常对应一个数据库事务或者一个应用事务,因此它的缓存是事务范围的缓存。第一级缓存是必需的,Session的缓存是内置的,不能被卸载。第二级缓存是一个可插拔的的缓存插件,它是由SessionFactory负责管理。由于SessionFactory对象的生命周期和应用程序的整个过程对应,因此第二级缓存是进程范围的缓存,第二级缓存是可选的,可以在每个类或每个集合的粒度上配置第二级缓存。当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查;查不到,如果配置了二级缓存,那么从二级缓存中查;查不到,再查询数据库,把结果按照ID放入到缓存。13:hibernate的连接池14:怎么接收dwr返回的数组或集合15:怎么读取一个文本文件〔流〕16:javascript中这么去掉字符串的空格17:用ajax的时候怎么运行后台返回的javascript代码18:存储过程是用来干什么的19:怎么终止一个线程抛出异常和等待run()方法结束。20.悲观锁和乐观锁?21.Oracle中实现序列用什么关键字?Sequence22.数据库中有哪些函数?23.解析XML的方法?DOM解析和SAX解析DOM:处理大型文件时其性能下降的非常厉害。这个问题是由DOM的树结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合对XML的随机访问SAX:不现于DOM,SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序访问24.用递归法求n的阶乘?25.Orcale中左右连接用“+〞怎样连接Oracle数据库左连接“+〞在右边,右连接“+〞在左边。26.Equals方法和==的区别。equals()方法是用来比拟两个字符串值是否相等而==是用来比拟对象引用是否相等(也就是是否为同一个对象)27.线程池的问题。线程池就像数据库连接池一样,是一个对象池。所有的对象池都有一个共同的目的,那就是为了提高对象的使用率,从而到达提高程序效率的目的。比方对于Servlet,它被设计为多线程的〔如果它是单线程的,你就可以想象,当1000个人同时请求一个网页时,在第一个人获得请求结果之前,其它999个人都在郁闷地等待〕,如果为每个用户的每一次请求都创立一个新的线程对象来运行的话,系统就会在创立线程和销毁线程上消耗很大的开销,大大降低系统的效率。因此,Servlet多线程机制背后有一个线程池在支持,线程池在初始化初期就创立了一定数量的线程对象,通过提高对这些对象的利用率,防止高频率地创立对象,从而到达提高程序的效率的目的。28.struts1的一些配置问题web.xml和struts-config.xml中的一些配置。JavaScript的一个操作流程。一些简单的sql语句,比方说现在数据库中有10记录,要求你写一个语句保存第二条和第五条记录,将其他的记录全部删除。存储过程、触发器Throw和Throws的区别throw语句用来明确地抛出一个“异常〞。throws用来标明一个成员函数可能抛出的各种“异常〞在异常捕获时try,catch,finally中可不可以没有catch语句块。可以,但try块不能单独执行,后面必须跟catch或者finally、或者两者都有。面向对象有哪些特征,你如何理解?抽象、继承、封装、多态什么是多线程?线程的状态有那几个?创立线程的方法?启动线程用什么方法?线程同步包括的方法?答:多线程是为了同步完成多项任务,不是为了提高运行效率,而是为了提高资源使用效率来提高系统的效率。线程是在同一时间需要完成多项任务的时候实现的。线程状态有:就绪、运行、挂起、结束。启动线程用start()方法。线程同步包含的方法:线程睡眠sleep()、线程让步:yield()、等待其他线程结束join()等。String、stringBuffer、StringBuilder的区别垃圾回收机制的原理?final,finally,finalize的区别?内存的泄露以及溢出是怎么回事?内存溢出就是你要求分配的java虚拟机内存超出了系统能给你的,系统不能满足需求,于是产生溢出。  内存泄漏是指你向系统申请分配内存进行使用(new),可是使用完了以后却不归还(delete),结果你申请到的那块内存你自己也不能再访问,该块已分配出来的内存也无法再使用,随着效劳器内存的不断消耗,而无法使用的内存越来越多,系统也不能再次将它分配给需要的程序,产生泄露。一直下去,程序也逐渐无内存使用,就会溢出。数据库连接池的原理?数据库连接池的根本思想就是为数据库连接建立一个“缓冲池〞。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池〞中取出一个,使用完毕之后再放回去。我们可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量﹑使用情况,为系统开发﹑测试及性能调整提供依据。数组和链表的区别?栈以及队列的特点以及区别?数组处理一组数据类型相同的数据,但不允许动态定义数组的大小,即在使用数组之前必须确定数组的大小。而在实际应用中,用户使用数组之前有时无法准确确定数组的大小,只能将数组定义成足够大小,这样数组中有些空间可能不被使用,从而造成内存空间的浪费。  链表是一种常见的数据组织形式,它采用动态分配内存的形式实现。需要时可以用new分配内存空间,不需要时用delete将已分配的空间释放,不会造成内存空间的浪费。数组中的数据在内存中的按顺序存储的,而链表是随机存储的!  要访问数组中的元素可以按下标索引来访问,速度比拟快,如果对他进行插入操作的话,就得移动很多元素,所以对数组进行插入操作效率很低!  由于连表是随机存储的,链表在插入,删除操作上有很高的效率〔相对数组〕,如果要访问链表中的某个元素的话,那就得从链表的头逐个遍历,直到找到所需要的元素为止,所以链表的随机访问的效率就比数组要低递归的算法?比方阶乘和fif数列的实现。常用的一些算法,如冒泡,二分查找,折半查找,选择排序等等java中多态是如何实现的?重载和覆盖的区别?注意代码的重构不是重载!接口和抽象类的区别?jsp和servlet的区别?jsp的内置对象?jsp的 标准 excel标准偏差excel标准偏差函数exl标准差函数国标检验抽样标准表免费下载红头文件格式标准下载 动作?jsp的页面元素有哪些?四种会话跟踪技术是什么?servlet是不是线程平安的?servlet生命周期?动态include和静态include区别?重定向和请求转发的区别?servlet中如何从页面获取参数?jsp的四种作用于范围是什么?Jsp是Servlet的技术扩展,本质上是Servlet的简易方式,Jsp侧重于视图而Servlet侧重于控制业务逻辑。Jsp内置对象九个:request、response、out、session、application、pagecantext、page、config、Exception会话跟踪技术:session、cookie、重写url、隐藏表单域Jsp标准动作:usebean、setProperty、getProperty、forward、include不是,servlet处于效劳器进程中,它通过多线程方式运行其service方法,一个实例可以效劳于多个请求,并且其实例一般不会销毁,所以你的工程中如果只有一个servlet,那么web容器就只会创立一个实例通过request.getParameter()来获取页面参数作用域范围由小到大:page、request、session、application47.jstl的包括哪些标签库?如何实现迭代?包括:核心标签〔包括通用标签、条件标签、迭代标签〕、I18N与国际化标签、SQL标签、XML标签、function标签使用迭代标签forEach来遍历48.过滤器的原理?过滤器的生命周期?监听器的原理hibernate的映射原理?hibernate的查询方式有哪些?关联关系的映射怎么理解?三种查询方式:HQL、条件查询、原生SQL查询,命名SQL、oracle和sqlserver区别?如何优化oracle数据库?oracle的一些常用系统函数?Oracle跨平台,SqlServer只能运行在window平台上。为什么要用索引?索引的分类?视图是什么?答:提高查询的执行速度,强制实施数据库的唯一性,提高表与表之间的链接速度。聚集索引和非聚集索引(SQLServer)标准索引、组合索引、唯一索引、反向索引、位图索引(Oracle)视图是一张虚拟表,该表提供对一个或多个表中列的访问,它是从一个或多个表中派生出来的对象。存储过程你是怎么理解的?如何实现?答:我感觉存储过程就像java中的方法一样,输入参数就是方法传的参数,而输出参数就像方法的返回值一样。Java中通过CallAbleStatement接口实现了对存储过程的调用。触发器、游标的一些根本知识!oracle数据库的一些特殊之处如簇、序列等如何理解簇是用来存储表的方法,这些表互相联系密切并通常相连在磁盘的相同区域上,共享同一列的一组表,用于检索时提高效率oracle中没有sqlserver中的标识列,只能通过创立序列来实现这一功能。权限的问题如何解决?Ajax的javaScript代码如何实现?Ajax的一些框架?单例模式和工厂模式如何实现?单列模式:〔饿汉式〕publicclassCar{privateCar(){}//私有的构造方法使别的类不能通过new来创立本类是类只能通过我们下面的方法来获得对象privatestaticCarbaoma=newCar();//静态类类型的变量保证对象只有一个publicstaticCargetCar(){//注意方法定义为静态的再别的类中就可以用本类类名来调用此方法得到本类对象returnbaoma;}}单列模式使本类对象只有一个,只能通过方法调用来获得对象,而且无论你掉用多少次方法,得到的都是一个实例。类的加载顺序父类静态块---->子类的静态块---->程序的入口(main)---->父类的初始化块---->父类的构造方法---->子类的初始化块------>子类的构造方法如何处理数据库差异比方用户刚开始使要求用SqlServer之后需求改变要使用Oracle:使用hibernate只需要改变方言即可使用sql标准语句Session和cookie的区别一个抽象类是否可以继承一个普通类可以,但被继承的类必须要有明确的构造方法什么时候用接口?抽象类?当你写一个类时,可能面临局部代码可能会发生变化  你可以把这些代码封装成〔接口或抽象类或根底类中的〕一个或多个方法  1、如果所有抽象出的方法不确定性很高,就定义为接口来封装,所有方法抽象,由实现类全部实现  2、如果局部抽象出的方法不确定性很高,就定义为抽象类来封装,能确定的方法实现,不确定的方法抽象,由实现类局部实现,局部重写〔不变就不重写啦〕  3、如果所有抽象出的方法确定性很高,就定义为根底类,所有方法提供根本实现,由子类去重写〔不变就不用写子类啦〕函数和存储过程的区别    1.   一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比拟强。    2.   对于存储过程来说可以返回参数,而函数只能返回值或者表对象。    3.   存储过程一般是作为一个独立的局部来执行,而函数可以作为查询语句的一个局部来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。    4.   当存储过程和函数被执行的时候,SQLManager会到procedurecache中去取相应的查询语句,如果在procedurecache里没有相应的查询语句,SQLManager就会对存储过程和函数进行编译。     Procedurecache中保存的是执行方案(executionplan),当编译好之后就执行procedurecache中的executionplan,之后SQLSERVER会根据每个executionplan的实际情况来考虑是否要在cache中保存这个plan,评判的标准一个是这个executionplan可能被使用的频率;其次是生成这个plan的代价,也就是编译的耗时。保存在cache中的plan在下次执行时就不用再编译了。Struts1和struts2比拟:Action类Struts1要求Action类要扩展自一个抽象基类。Struts1的一个共有的问题是面向抽象类编程而不是面向接口编程。Struts2的Action类实现了一个Action接口,连同其他接口一起实现可选择和自定义的效劳。Struts2提供一个名叫ActionSupport的基类实现一般使用的接口。虽然,Action接口不是必须的。任何使用execute方法的POJO对象可以被当作Struts2的Action对象使用。程模型Struts1Action类是单例类,因只有一个例如控制所有的请求。单例类策略造成了一定的限制且给开发带来了额外的烦恼。Action资源必须是程平安或者同步的。Struts2Action对象每一个请求都实例化对象,所以没有程平安的问题。〔实践中,servlet容器生许多丢的对象对于每一个请求,多于一个的对象并不影响垃圾收集〕Servlet依赖Struts1的Action类依赖于servletAPI以HttpServletRequest和HttpServletResponse作参数传给execute方法当Action被调用时。Struts2的Action不和容器有关。Servlet上下文被表现简单的Maps,允许Action被独立的测试。Struts2的Action可以访问最初的请求和相应,如果需要的话。然而,其他的架构元素少或者排除直接访问HttpServletRequest或者HttpServletResponse的需要。易测性测试Struts1的主要障碍是execute方法暴露了ServletAPI。第三方的扩展,Struts测试用例,提供Struts1的集合对象。Struts2的Action可以通过实例化Action测试,设置属性,然后调用方法。依赖注入的支持也是测试变得更简单。接受输入Struts1使用ActionForm对象捕获输入。象Action一样,所有的ActionForm必须扩展基类。因其他的JavaBean不能作ActionForm使用,开发者经常创立多余的类捕获输入。DynaBeans可以被用来作替代ActionForm的类创立。但是开发者可以重新描述已经存在的JavaBean。Struts2Action属性作输入属性,排除第二个输入对象的需要。输入属性可能有丰富的对象类型这些类型有他们自己的属性。Action的属性可以通过标签库访问。Struts2也支持ActionForm形式。丰富的对象类型,包含业务或者域对象,可以被当作输入或者输出对象使用。馍型驱动特性简化标签对POJO输入对象的引用。表达式语言Struts1整和JSTL,所以它使用JSTL的表达式语言。表达式语言有根本的图形对象移动,但是相对很弱的集合和被索引的属性支持。Struts2使用JSTL,但是框架也支持更大和更灵活的表达式,叫做“对象图形符号语言〞〔OGNL〕。将值绑定要视图上Struts1使用标准JSP机制来绑定对象到页面上下文。Struts2使用“ValueStack〞技术了标签库可以不用链接你的视图到对象的表现类型访问值。ValueStack策略允许重用视图。类型转换Struts1的ActionForm属性经常都是String的。Struts1使用Commons-Beanutils类型转换。转换每一个类,不是每一个实例配置。Struts2使用OGNL类型转换。框架包含转换器根本的和共同的对象类型和原始类型。验证Struts1支持手动验证凭借ActionForm的validate方法,或者通过扩展的公用验证器。类可以有不同的验证上下文未相同的类,但是不能不能包括验证子对象。Struts2支持手动验证凭借validate方法和XWork验证框架。Xwork验证框架支持一连串的验证子属性使用的验证了属性类的类型和严正上下文而定义。Action执行的控制Struts1支持独立的请求处理器对于每一个模型,但是所有在模型中的Action必须共享同一个生命周期。Struts2支持在每一个Action根底上凭借拦截栈创立不同的生命周期。自定义栈可以被创立且使用不同的所需的Action
本文档为【软通动力面试题集】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
机构认证用户
在一起网络科技公司
本公司成立于2019年8月,公司员工20多名、有经验丰富的团队。擅长网络软件设计、制作;PPT设计;平面广告设计;品牌设计;软件和信息技术服务、合同范本制作
格式:doc
大小:38KB
软件:Word
页数:0
分类:
上传时间:2021-09-13
浏览量:7