面试题_异常

一、面试题

1、throw 和 throws 的区别?

  • throw:是真实抛出一个异常对象,在方法体内。
  • throws:是声明可能会抛出一个异常类,在方法上。

2、final、finally、finalize 有什么区别?

  • final:是修饰符,如果修饰类,此类不能被继承;如果修饰方法和变量,则表示此方法和此变量不能在被改变,只能使用。
  • finally:是 try{} catch{} finally{} 最后一部分,表示不论发生任何情况都会执行,finally 部分可以省略,但如果 finally 部分存在,则一定会执行 finally 里面的代码。
  • finalize: 是 Object 类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法。

3、try-catch-finally 中哪个部分可以省略?

try-catch-finally 其中 catch 和 finally 都可以被省略,但是不能同时省略,也就是说有 try 的时候,必须后面跟一个 catch 或者 finally。

4、try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?

finally 一定会执行,即使是 catch 中 return 了,catch 中的 return 会等 finally 中的代码执行完之后,才会执行。

5、常见的异常类有哪些?

  • NullPointerException 空指针异常
  • ClassNotFoundException 指定类不存在
  • NumberFormatException 字符串转换为数字异常
  • IndexOutOfBoundsException 数组下标越界异常
  • ClassCastException 数据类型转换异常
  • FileNotFoundException 文件未找到异常
  • NoSuchMethodException 方法不存在异常
  • IOException IO 异常
  • SocketException Socket 异常

二、面试题

1、 Java中什么是Exception?

​ Throwable把错误进一步划分为 java.lang.Exception 和 java.lang.Error. java.lang.Error 用

来处理系统错误,例如java.lang.StackOverFlowError 或者 Java.lang.OutOfMemoryError 之类的。然后

Exception用来处理程序错误,请求的资源不可用等等。

2、Java中的检查型异常和非检查型异常有什么区别?

检查型异常和非检查型异常的主要区别在于其处理方式。

​ 检查型异常需要使用try, catch和finally关键字在编译期进行处理,否则会出现编译器会报错。

​ 对于非检查型异常则不需要这样做。Java中所有继承自java.lang.Exception类的异常都是检查型

异常,所有继承自RuntimeException的异常都被称为非检查型异常。

3、在Java异常处理的过程中,你遵循的那些最好的实践是什么?**

1) 调用方法的时候返回布尔值来代替返回null,这样可以 NullPointerException。由于空指针是java异常里最恶

心的异常。

  1. catch块里别不写代码。空catch块是异常处理里的错误事件,因为它只是捕获了异常,却没有任何处理或者

提示。通常你起码要打印出异常信息,当然你最好根据需求对异常信息进行处理。*****

3)能抛受控异常(checked Exception)就尽量不抛受非控异常(checked Exception)。通过去掉重复的异常处

理代码,可以提高代码的可读性。

  1. 绝对不要让你的数据库相关异常显示到客户端。由于绝大多数数据库和SQLException异常都是受控异常,在Java中,

你应该在DAO层把异常信息处理,然后返回处理过的能让用户看懂并根据异常提示信息改正操作的异常信息。

  1. 在Java中,一定要在数据库连接,数据库查询,流处理后,在finally块中调用close()方法。

5、既然我们可以用RuntimeException来处理错误,那么你认为为什么Java中还存在检查型异常?

这是一个有争议的问题,在回答该问题时你应当小心。虽然他们肯定愿意听到你的观点,但其实他们最感兴

趣的还是有说服力的理由。我认为其中一个理由是,存在检查型异常是一个设计上的决定,受到了诸如C++等比

Java更早的编程语言设计经验的影响。绝大多数检查型异常位于java.io包内,这是合乎情理的,因为在你请求了

不存在的系统资源的时候,一段强壮的程序必须能够优雅的处理这种情况。通过把IOException声明为检查型异

常,Java 确保了你能够优雅的对异常进行处理。另一个可能的理由是,可以使用catch或finally来确保数量受限

的系统资源(比如文件描述符)在你使用后尽早得到释放。

6、throw 和 throws这两个关键字在java中有什么不同?

throws 总是出现在一个函数头中,用来标明该成员函数可能抛出的各种异常, 你也可以申明未检查的异常,但这不是编译

器强制的。如果方法抛出了异常那么调用这个方法的时候就需要将这个异常处理。

另一个关键字 throw 是用来抛出任意异常的,按照语法你可以抛出任意 Throwable (i.e. Throwable 或任何Throwable的衍生类) , throw

可以中断程序运行,因此可以用来代替return . 最常见的例子是用 throw 在一个空方法中需要return的地方抛出 UnSupportedOperationException 代码如下 :

1 private static voidshow() {
2 throw new UnsupportedOperationException(“Not yet implemented”);
3 }

7、什么是“异常链”?**

“异常链”是Java中非常流行的异常处理概念,是指在进行一个异常处理时抛出了另外一个异常,由此产生

了一个异常链条。该技术大多用于将“ 受检查异常” ( checked exception)封装成为“非受检查异常”

(unchecked exception)或者RuntimeException。顺便说一下,如果因为因为异常你决定抛出一个新的异常,

你一定要包含原有的异常,这样,处理程序才可以通过getCause()和initCause()方法来访问异常最终的根源。

8、你曾经自定义实现过异常吗?怎么写的?**

很显然,我们绝大多数都写过自定义或者业务异常,像AccountNotFoundException。在面试过程中询问

这个Java异常问题的主要原因是去发现你如何使用这个特性的。这可以更准确和精致的去处理异常,当然这也跟

你选择checked 还是unchecked exception息息相关。通过为每一个特定的情况创建一个特定的异常,你就为

调用者更好的处理异常提供了更好的选择。相比通用异常(general exception),我更倾向更为精确的异常。大

量的创建自定义异常会增加项目class的个数,因此,在自定义异常和通用异常之间维持一个平衡是成功的关键。

9、JDK7中对异常处理做了什么改变?**

这是最近新出的Java异常处理的面试题。JDK7中对错误(Error)和异常(Exception)处理主要新增加了2个特性,

一是在一个catch块中可以出来多个异常,就像原来用多个catch块一样。另一个是自动化资源管理(ARM), 也称为

try-with-resource块。这2个特性都可以在处理异常时减少代码量,同时提高代码的可读性。对于这些特性了解,

不仅帮助开发者写出更好的异常处理的代码,也让你在面试中显的更突出。我推荐大家读一下Java 7攻略,这样

可以更深入的了解这2个非常有用的特性。

10、你遇到过 OutOfMemoryError 错误嘛?你是怎么搞定的?**

这个面试题会在面试高级程序员的时候用,面试官想知道你是怎么处理这个危险的OutOfMemoryError错误的。

必须承认的是,不管你做什么项目,你都会碰到这个问题。所以你要是说没遇到过,面试官肯定不会买账。要是

你对这个问题不熟悉,甚至就是没碰到过,而你又有3、4年的Java经验了,那么准备好处理这个问题吧。在回答

这个问题的同时,你也可以借机向面试秀一下你处理内存泄露、调优和调试方面的牛逼技能。我发现掌握这些技

术的人都能给面试官留下深刻的印象。

11、 如果执行finally代码块之前方法返回了结果,或者JVM退出了,finally块中的代码还会执行吗?**

这个问题也可以换个方式问:“如果在try或者finally的代码块中调用了System.exit(),结果会是怎样”。

了解finally块是怎么执行的,即使是try里面已经使用了return返回结果的情况,对了解Java的异常处理都非常

有价值。只有在try里面是有System.exit(0)来退出JVM的情况下finally块中的代码才不会执行。

12、Java中final,finalize,finally关键字的区别**

这是一个经典的Java面试题了。我的一个朋友为Morgan Stanley招电信方面的核心Java开发人员的时候就

问过这个问题。final和finally是Java的关键字,而finalize则是方法。final关键字在创建不可变的类的时候

非常有用,只是声明这个类是final的。而finalize()方法则是垃圾回收器在回收一个对象前调用,但也Java规

范里面没有保证这个方法一定会被调用。finally关键字是唯一一个和这篇文章讨论到的异常处理相关的关键字。

在你的产品代码中,在关闭连接和资源文件的是时候都必须要用到finally块。

13、 下面的代码都有哪些错误:**

01 public static void start() throws IOException, RuntimeException{
02
03 throw new RuntimeException(“Not able to Start”);
04 }
05
06 public static void main(String args[]) {
07 try {
08 start();
09 } catch (Exception ex) {
10 ex.printStackTrace();
11 } catch (RuntimeException re) {
12 re.printStackTrace();
13 }
14 }

这段代码会在捕捉异常代码块的RuntimeException类型变量“re”里抛出编译异常错误。因为Exception是RuntimeException的超类,在start方法中所有的RuntimeException会被第一个捕捉异常块捕捉,这样就无法到

达第二个捕捉块,这就是抛出“exception java.lang.RuntimeException has already been caught”的编译错误原因。

14、下面的Java代码都有哪些错误:**

01 public classSuperClass {
02 public void start() throws IOException{
03 throw new IOException(“Not able to open file”);
04 }
05 }
06
07 public class SubClass extendsSuperClass{
08 public void start() throws Exception{
09 throw new Exception(“Not able to start”);
10 }
11 }

这段代码编译器将对子类覆盖start方法产生不满。因为每个Java中方法的覆盖是有规则的,一个覆盖的方法

不能抛出的异常比原方法继承关系高。因为这里的start方法在超类中抛出了IOException,所有在子类中的start

方法只能抛出要么是IOExcepition或是其子类,但不能是其超类,如Exception。

15、下面的Java异常代码有什么错误:**

01 public static void start(){
02 System.out.println(“Java Exception interivew question Answers for Programmers”);
03 }
04
05 public static void main(String args[]) {
06 try{
07 start();
08 }catch(IOException ioe){
09 ioe.printStackTrace();
10 }
11 }

上面的Java异常例子代码中,编译器将在处理IOException时报错,因为IOException是受检查异常,而start

方法并没有抛出IOException,所以编译器将抛出“异常, java.io.IOException 不会在try语句体中抛出”,但

是如果你将IOException改为Exception,编译器报错将消失,因为Exception可以用来捕捉所有运行时异常,这样

就不需要声明抛出语句。我喜欢这样带有迷惑性的Java异常面试题,因为它不会让人轻易的找出是IOException还

是Exception。你也可以在 Joshua Bloach和Neil Gafter的Java谜题中找到一些有关Java错误和异常的具有迷惑

性问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值