1. Struts的运行机制:
Web应用初始化时,控制器加载分析配置文件(struts-config.xml),获得ActionMapping,配置应用程序
1. ActionServlet接收用户请求
2. ActionServlet根据应用程序配置填充ActionForm
3. ActionServlet根据ActionMapping调用Action的execute方法
4. Action调用业务逻辑类(Model),在简单的程序中也可以在Action的execute方法中执行业务处理
5. 业务逻辑类将处理结果返回给Action,Action将处理结果保存在适当的作用域范围之内(session、request等)
6. Action的execute方法向ActionServlet返回ActionForward指明下一步调用的Action或JSP视图
7. JSP视图取得保存在作用域之中的业务处理结果并负责显示HTML页面
大家最好用自己的话来总结出来!
2. 常用的集合以及介绍:(应重点复习)
常用集合set、map、list
set、map是collection接口的子接口
set接口的实现类:HashSet、TreeSet
List接口的实现类:ArrayList、linkedList
Map接口的实现类:HashMap、TreeMap、Hashtable。
ArrayList和linkedList的区别(略)
List: 有顺序的,元素可以重复
遍历:for 迭代
排序:Comparable Comparator Collections.sort()
ArrayList:底层用数组实现的List
特点:查询效率高,增删效率低 轻量级 线程不安全
遍历:
ArrayList<String>al=new ArrayList();
al.add("winsun"); al.add("weixin"); al.add("mybole");
for(inti=0;i<al.size();i++)
{
System.out.println(al.get(i));
}//for遍历
Iteratorit=al.iterator();
while(it.hasNext())
{
System.out.println(it.next());
}//迭代器遍历
LinkedList:底层用双向循环链表实现的List
特点:查询效率低,增删效率高
Vector: 底层用数组实现List接口的另一个类
特点:重量级,占据更多的系统开销 线程安全
HashMap、HashTable区别(略)
Hashtable和HashMap类有三个重要的不同之处。第一个不同主要是历史原因。Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现。
也许最重要的不同是Hashtable的方法是同步的,而HashMap的方法不是。这就意味着,虽然你可以不用采取任何特殊的行为就可以在一个多线程的应用程序中用一个Hashtable,但你必须同样地为一个HashMap提供外同步。一个方便的方法就是利用Collections类的静态的synchronizedMap()方法,它创建一个线程安全的Map对象,并把它作为一个封装的对象来返回。这个对象的方法可以让你同步访问潜在的HashMap。这么做的结果就是当你不需要同步时,你不能切断Hashtable中的同步(比如在一个单线程的应用程序中),而且同步增加了很多处理费用。
第三点不同是,只有HashMap可以让你将空值作为一个表的条目的key或value。HashMap中只有一条记录可以是一个空的key,但任意数量的条目可以是空的value。这就是说,如果在表中没有发现搜索键,或者如果发现了搜索键,但它是一个空的值,那么get()将返回null。如果有必要,用containKey()方法来区别这两种情况。
一些资料建议,当需要同步时,用Hashtable,反之用HashMap。但是,因为在需要时,HashMap可以被同步,HashMap的功能比Hashtable的功能更多,而且它不是基于一个陈旧的类的,所以有人认为,在各种情况下,HashMap都优先于Hashtable。
3. 遍历map的方法:
使用Map接口提供的方法entrySet();
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
public class MapTest {
public staticvoid main(String[] args) {
Map<Object,Object> map = new HashMap<Object,Object>();
map.put("a","中国");
map.put("b","ABC");
map.put("c",1000);
/*for(Iterator<Entry<Object,Object>>it = map.entrySet().iterator();it.hasNext();){
Entry<Object,Object>entry = it.next();
System.out.println(entry);
System.out.println(entry.getKey());
System.out.println(entry.getValue());
}*/
for(Iterator<Object>it = 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()只是将字符串追加到原字符串的尾部,始终都是一个对象!
5. 垃圾回收机制原理:
当一个对象赋值为null或者没有指引指向他的时候,那么这个对象就符合垃圾回收机制回收的范围,java虚拟机会不定时的对垃圾进行回收,回收对象之前会调用被回收对象的finalize()方法!
注意Java虚拟机何时来回收垃圾不确定!
6. 如何实现多线程:
继承Thread类或者实现Runnable接口
那种好处多:因为java是单继承所以一般会采用实现Runnable接口
两种实现方式的区别:
继承Thread类可以创建本类对象直接调用start()方法运行线程(也就是说本类对象就是一个线程 个人理解)
实现Runnable接口必须用Thread thread = new Thread()来获得一个线程!
7.代码的重构:
代码的输入、输出不变,只是改变中间实现代码!
8. MVC思想
是model、view、controller的缩写,model代表业务逻辑(通过javabean、EJB组建实现)、view是应用表示面(由jsp页面产生)、controller是提供应用处理过程的控制(一般是一个servlet)。通过这种设计模式把应用逻辑、处理过程、显示逻辑分成不同的组件实现,可提高组件的交互和重用性。
9. struts1和struts2的区别(见最后一页)
10: 讲解一下Spring
11: hibernate是怎么工作的
原理:
1. 读取并解析配置文件
2. 读取并解析映射信息,创建SessionFactory
3. 打开Sesssion
4. 创建事务Transation
5. 持久化操作
6. 提交事务
7. 关闭Session
8. 关闭SesstionFactory
12: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中实现序列用什么关键字?
Sequence
22. 数据库中有哪些函数?
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中的一些配置。
29. JavaScript的一个操作流程。
30. 一些简单的sql语句,比如说现在数据库中有10记录,要求你写一个语句保留第二条和第五条记录,将其他的记录全部删除。
31. 存储过程、触发器
32. Throw和Throws的区别
throw语句用来明确地抛出一个“异常”。throws用来标明一个成员函数可能抛出的各种“异常”
33. 在异常捕获时try ,catch,finally中可不可以没有catch语句块。
可以,但try块不能单独执行,后面必须跟catch或者finally、或者两者都有。
34. 面向对象有哪些特征,你如何理解?
抽象、继承、封装、多态
35. 什么是多线程?线程的状态有那几个?创建线程的方法?启动线程用什么方法?线程同步包括的方法?
答:多线程是为了同步完成多项任务,不是为了提高运行效率,而是为了提高资源使用效率来提高系统的效率。线程是在同一时间需要完成多项任务的时候实现的。线程状态有:就绪、运行、挂起、结束。启动线程用start()方法。线程同步包含的方法:线程睡眠sleep()、线程让步:yield()、等待其他线程结束join()等。
36. String、stringBuffer、StringBuilder的区别
37. 垃圾回收机制的原理?final,finally,finalize的区别?
38. 内存的泄露以及溢出是怎么回事?
内存溢出就是你要求分配的java虚拟机内存超出了系统能给你的,系统不能满足需求,于是产生溢出。
内存泄漏是指你向系统申请分配内存进行使用(new),可是使用完了以后却不归还(delete),结果你申请到的那块内存你自己也不能再访问,该块已分配出来的内存也无法再使用,随着服务器内存的不断消耗,而无法使用的内存越来越多,系统也不能再次将它分配给需要的程序,产生泄露。一直下去,程序也逐渐无内存使用,就会溢出。
39. 数据库连接池的原理?
数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。我们可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量﹑使用情况,为系统开发﹑测试及性能调整提供依据。
40. 数组和链表的区别?栈以及队列的特点以及区别?
数组处理一组数据类型相同的数据,但不允许动态定义数组的大小,即在使用数组之前必须确定数组的大小。而在实际应用中,用户使用数组之前有时无法准确确定数组的大小,只能将数组定义成足够大小,这样数组中有些空间可能不被使用,从而造成内存空间的浪费。
链表是一种常见的数据组织形式,它采用动态分配内存的形式实现。需要时可以用new分配内存空间,不需要时用delete将已分配的空间释放,不会造成内存空间的浪费。
数组中的数据在内存中的按顺序存储的,而链表是随机存储的!
要访问数组中的元素可以按下标索引来访问,速度比较快,如果对他进行插入操作的话,就得移动很多元素,所以对数组进行插入操作效率很低!
由于连表是随机存储的,链表在插入,删除操作上有很高的效率(相对数组),如果要访问链表中的某个元素的话,那就得从链表的头逐个遍历,直到找到所需要的元素为止,所以链表的随机访问的效率就比数组要低
41. 递归的算法?比如阶乘和fif数列的实现。常用的一些算法,如冒泡,二分查找,折半查找,选择排序等等
42. java中多态是如何实现的?重载和覆盖的区别?注意代码的重构不是重载!
43. 接口和抽象类的区别?
44. jsp和servlet的区别?jsp的内置对象?jsp的标准动作?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、application
47. jstl的包括哪些标签库?如何实现迭代?
包括:核心标签(包括通用标签、条件标签、迭代标签)、I18N与国际化标签、SQL标签、XML标签、function标签
使用迭代标签forEach来遍历
48. 过滤器的原理?过滤器的生命周期?监听器的原理
49. hibernate的映射原理?hibernate的查询方式有哪些?
关联关系的映射怎么理解?
三种查询方式:HQL、条件查询、原生SQL查询,命名SQL、
50. oracle和sqlserver区别?如何优化oracle数据库?oracle的一些常用系统函数?
Oracle跨平台,Sql Server只能运行在window平台上。
51. 为什么要用索引?索引的分类?视图是什么?
答:提高查询的执行速度,强制实施数据库的唯一性,提高表与表之间的链接速度。聚集索引和非聚集索引(SQL Server)
标准索引、组合索引、唯一索引、反向索引、位图索引(Oracle)
视图是一张虚拟表,该表提供对一个或多个表中列的访问,它是从一个或多个表中派生出来的对象。
52. 存储过程你是怎么理解的?如何实现?
答:我感觉存储过程就像java中的方法一样,输入参数就是方法传的参数,而输出参数就像方法的返回值一样。Java中通过CallAbleStatement接口实现了对存储过程的调用。
53. 触发器、游标的一些基本知识!
54. oracle数据库的一些特殊之处如簇、序列等如何理解
簇是用来存储表的方法,这些表互相联系密切并通常相连在磁盘的相同区域上,共享同一列的一组表,用于检索时提高效率
oracle中没有sql server中的标识列,只能通过创建序列来实现这一功能。
55. 权限的问题如何解决?
56. Ajax的javaScript代码如何实现?Ajax的一些框架?
57. 单例模式和工厂模式如何实现?
单列模式:(饿汉式)
public class Car{
privateCar(){}//私有的构造方法使别的类不能通过new来创建本类是类只能通过我们下面的方法来获得对象
privatestatic Car baoma = new Car();//静态类类型的变量保证对象只有一个
publicstatic Car getCar(){//注意方法定义为静态的再别的类中就可以用本类类名来调用此方法得到本类对象
returnbaoma;
}
}
单列模式使本类对象只有一个,只能通过方法调用来获得对象,而且无论你掉用多少次方法,得到的都是一个实例。
58. 类的加载顺序
父类静态块---->子类的静态块---->程序的入口(main)---->父类的初始化块---->父类的构造方法---->子类的初始化块------>子类的构造方法
59. 如何处理数据库差异
比如用户刚开始使要求用SqlServer之后需求改变要使用Oracle:
a) 使用hibernate只需要改变方言即可
b) 使用sql标准语句
60. Session和cookie的区别
61. 一个抽象类是否可以继承一个普通类
可以,但被继承的类必须要有明确的构造方法
62. 什么时候用接口?抽象类?
当你写一个类时,可能面临部分代码可能会发生变化
你可以把这些代码封装成(接口或抽象类或基础类中的)一个或多个方法
1、如果所有抽象出的方法不确定性很高,就定义为接口来封装,所有方法抽象,由实现类全部实现
2、如果部分抽象出的方法不确定性很高,就定义为抽象类来封装,能确定的方法实现,不确定的方法抽象,由实现类部分实现,部分重写(不变就不重写啦)
3、如果所有抽象出的方法确定性很高,就定义为基础类,所有方法提供基本实现,由子类去重写(不变就不用写子类啦)
63. 函数和存储过程的区别
1. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
2. 对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
3. 存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
4. 当存储过程和函数被执行的时候,SQL Manager会到procedure cache中去取相应的查询语句,如果在procedure cache里没有相应的查询语句,SQL Manager就会对存储过程和函数进行编译。
Procedure cache中保存的是执行计划 (execution plan) ,当编译好之后就执行procedure cache中的execution plan,之后SQL SERVER会根据每个execution plan的实际情况来考虑是否要在cache中保存这个plan,评判的标准一个是这个execution plan可能被使用的频率;其次是生成这个plan的代价,也就是编译的耗时。保存在cache中的plan在下次执行时就不用再编译了。