java面试必背代码 java面试题( 五 )


6、运行时异常与一般异常有何异同?
异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误 。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常 。
7、说出Servlet的生命周期,并说出Servlet和CGI的区别 。
Servlet被服务器实例化后,容器运行其init方法 , 请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法 。
与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁 , 所以效率上低于servlet 。
8、说出ArrayList,Vector, LinkedList的存储性能和特性
ArrayList和 Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素 , 它们都允许直接按序号索引元素,但是插入元素要涉及数组元素 移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差 , 而 LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快 。
10、和的区别 。
是位运算符 , 表示按位与运算,是逻辑运算符,表示逻辑与(and) 。
11、HashMap和Hashtable的区别 。
HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable 。
HashMap允许将null作为一个entry的key或者value,而Hashtable不允许 。
HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey 。因为contains方法容易让人引起误解 。
Hashtable继承自Dictionary类,而HashMap是Java1.2引进的Map interface的一个实现 。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的方法实现同步,而HashMap 就必须为之提供外同步 。
Hashtable和HashMap采用的hash/rehash算法都大概一样,所以性能不会有很大的差异 。
12、final, finally, finalize的区别 。
final 用于声明属性 , 方法和类,分别表示属性不可变 , 方法不可覆盖,类不可继承 。
finally是异常处理语句结构的一部分,表示总是执行 。
finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收 , 例如关闭文件等 。
13、sleep() 和 wait() 有什么区别?
sleep是线程类(Thread)的方法 , 导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复 。调用sleep不会释放对象锁 。
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态 。
14、Overload和Override的区别 。Overloaded的方法是否可以改变返回值的类型?
方法的重写Override和重载Overload是Java多态性的不同表现 。重写Overrid是父类与子类之间多态性的一种表现 , 重载 Overload是一个类中多态性的一种表现 。如果在子类中定义某方法与其父类有相同的名称和参数 , 我们说该方法被重写 (Overrid) 。子类的对象使用这个方法时 , 将调用子类中的定义,对它而言,父类中的定义如同被"屏蔽"了 。如果在一个类中定义了多个同名的方 法 , 它们或有不同的参数个数或有不同的参数类型,则称为方法的重载(Overloading) 。Overload的方法是可以改变返回值的类型 。

推荐阅读