您的位置:首页 > 编程语言 > Java开发

Java知识点19

2016-08-20 11:59 197 查看
异常分两种: 

1:编译时被检查的异常,只要是Exception及其子类都是编译时被检测的异常。 

2:运行时异常,其中Exception有一个特殊的子类RuntimeException,以及RuntimeException的子类是运行异常,也就说这个异常是编译时不被检查的异常。  

编译时被检查的异常和运行时异常的区别: 

编译被检查的异常在函数内被抛出,函数必须要声明,否编译失败。 声明的原因:是需要调用者对该异常进行处理。 

运行时异常如果在函数内被抛出,在函数上不需要声明。 

不声明的原因:不需要调用者处理,运行时异常发生,已经无法再让程序继续运行,所以,不让调用处理的,直接让程序停止,由调用者对代码进行修正。  

定义异常处理时,什么时候定义try,什么时候定义throws呢? 功能内部如果出现异常,如果内部可以处理,就用try; 
如果功能内部处理不了,就必须声明出来,让调用者处理。使用throws抛出,交给调用者处理。谁调用了这个功能谁就是调用者;

自定义异常:当开发时,项目中出现了java中没有定义过的问题时,这时就需要我们按照java异常建立思想,将项目的中的特有问题也进行对象的封装。这个异常,称为自定义异常。  

对于除法运算,0作为除数是不可以的。java中对这种问题用ArithmeticException类进行描述。对于这个功能,在我们项目中,除数除了不可以为0外,还不可以为负数。可是负数的部分java并没有针对描述。所以我们就需要自定义这个异常。  

自定义异常的步骤: 

1:定义一个子类继承Exception或RuntimeException,让该类具备可抛性(既可以使用throw和throws去调用此类)。 

2:通过throw 或者throws进行操作。

异常的转换思想:当出现的异常是调用者处理不了的,就需要将此异常转换为一个调用者可以处理的异常抛出。  

try  catch  finally的几种结合方式: 

1, try  catch finally  

这种情况,如果出现异常,并不处理,但是资源一定关闭,所以try  finally集合只为关闭资源。 记住:finally很有用,主要用户关闭资源。无论是否发生异常,资源都必须进行关闭。 System.exit(0); //退出jvm,只有这种情况finally不执行。  

当异常出现后,在子父类进行覆盖时,有了一些新的特点: 

1:当子类覆盖父类的方法时,如果父类的方法抛出了异常,那么子类的方法要么不抛出异常要么抛出父类异常或者该异常的子类,不能抛出其他异常。 

2:如果父类抛出了多个异常,那么子类在覆盖时只能抛出父类的异常的子集。  

注意: 

如果父类或者接口中的方法没有抛出过异常,那么子类是不可以抛出异常的,如果子类的覆盖的方法中出现了异常,只能try不能throws。 

如果这个异常子类无法处理,已经影响了子类方法的具体运算,这时可以在子类方法中,通过throw抛出RuntimeException异常或者其子类,这样,子类的方法上是不需要throws声明的。

常见异常: 

1、脚标越界异常(IndexOutOfBoundsException)包括数组、字符串; 空指针异常(NullPointerException) 2、类型转换异常:ClassCastException 

3、没有这个元素异常:NullPointerException 4、不支持操作异常; 

异常要尽量避免,如果避免不了,需要预先给出处理方式。比如家庭备药,比如灭火器。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息