java为什么 会编译时异常(java编译异常有哪几个)
大家好,今天来为大家解答java为什么 会编译时异常这个问题的一些问题点,包括java编译异常有哪几个也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~
java编译异常有哪几个
编译异常是Exception下除了RuntimeException及其子类以外的所有子类
Java提供了两类主要的异常:RuntimeException和CheckedException.
checked异常也就是我们经常遇到的IO异常,以及SQL异常都是这种异常。对于这种异常,JAVA编译器强制要求我们必需对出现的这些异常进行catch。所以,面对这种异常不管我们是否愿意,只能自己去写一大堆catch块去处理可能的异常。
runtime exception,也称运行时异常,我们可以不处理。当出现这样的异常时,总是由虚拟机接管。比如:我们从来没有人去处理过NullPointerException异常,它就是运行时异常,并且这种异常还是最常见的异常之一。
不管是不是RuntimeException只要有异常而且你还没try/ catch那他一定会中断执行非RuntimeException在编译的时候编译器会帮你检查有没有正确、完整的try/ catch如果没有编译不过 RuntimeException在编译的时候不检查
参考自:http://m.blog.csdn.net/blog/zhou1216141078/12921609
Java之运行时异常与编译时异常区别
Java中用2种方法处理异常:
1.在发生异常的地方直接处理;
2.将异常抛给调用者,让调用者处理。
Java常见的异常:
(1)编译时异常:Java.lang.Exception
(2)运行期异常:Java.lang.RuntimeException
Java.lang.Exception和Java.lang.Error继承自Java.lang.Throwable;
Java.lang.RuntimeException继承自Java.lang.Exception.
编译时异常:程序正确,但因为外在的环境条件不满足引发。例如:用户错误及I/O问题----程序试图打开一个并不存在的远程Socket端口。这不是程序本身的逻辑错误,而很可能是远程机器名字错误(用户拼写错误)。对商用软件系统,程序开发者必须考虑并处理这个问题。Java编译器强制要求处理这类异常,如果不捕获这类异常,程序将不能被编译。
运行期异常:这意味着程序存在bug,如数组越界,0被除,入参不满足规范.....这类异常需要更改程序来避免,Java编译器强制要求处理这类异常。
JAVA反射为什么总要异常处理
JAVA中的异常和反射
一、异常
1
、异常概貌:
概念: JAVA会将所有的异常、错误抽象成为一个类,其根本父类为Throwable。异常是程
序中所有出乎意料的结果,用名称代表发生的问题,见名知义。我们对于程序可能出现的错
误应该做出预案。异常处理可以提高我们系统的容错性、健壮性。
java.lang.Throwable类是所有异常和错误的顶层类。其两个直接子类是java.lang.Error和
java.lang.Exception。
Error
对象表示程序错误,是底层的、不可恢复的严重错误。此时程序一定会退出,
已经失去了运行所必须的物理环境。因为程序已经退出了,所以对于Error错误无法进
行处理。
我们可处理的只是Exception
类的对象表示的程序异常(例外/异常)。
以下区分:
RuntimeException
(未检查异常):RuntimeException及其子类都称为运行时异常,它
是(UnChecked Exception),特点是Java编译器不会检查它,可以在编程时避免。也就
是说,当程序中出现此类异常时,即使不用try…catch捕获,或不用throws子句抛出,
还是可以编译通过。比如,除数为0的异常ArrithmeticException,就是运行时异常。
非Runtime
异常(已检查异常):包括除了RuntimeException及其子类外的其它Exception
类及其子类,都属于已检查异常(Checked Exception)。其特点是Java编译器会检查它,
我们需要用try…catch语句捕获,或用throws子句声明抛出,否则编译不会通过。比如
打开文件时找不到文件,就属于已检查异常。
Throwable
Error
错误
严重底层错误
不可避免
不可处理
Exception
异常
RuntimeException
未检查异常
(可处理可不处理)
比如除0错误、空指针
非Runtime
已检查异常
(必须处理)
比如打开文件时找不到
2
2
、Java
异常处理机制
(1
)try
…
catch
捕获异常(积极处理异常的方式)
try代码块包含了可能发生异常的程序代码,catch块紧随其后,用来捕获并处理异常。
格式如下:
try
{
可能出现异常的代码块}
catch
(Exception
e)
{
进行异常处理}
注意:一次异常捕获只会匹配一次try…catch
catch中要求必须先捕获子类异常再捕获父类异常。
(2
)finally
任何情况下都必须执行的代码段(紧接在try或catch代码块后面)。
finally无论如何都会被执行,除非JVM退出。所以,finally代码块常常用于释放被占
用的资源。比如关闭文件、网络、数据库连接等。
(3
)throws
声明可能会抛出的异常(消极处理异常的方式)
格式:方法名(参数表)throws
后面接要往上抛的异常。
表示该方法对指定的异常不作任何处理,直接抛往上一层。
static void methodA(int i) throws IOException{//一直向上抛(消极处理)
}
public static void main(String[] args) throws IOException{//一直抛到JVM
}
多个异常,用逗号隔开。throws IOException, SQLException
throws后的异常允许多态。比如IOException,会包括抛出其子类。
注意:不允许子类比父类抛出范围更大、更多的异常。
方法覆盖时,修饰符要越来越宽;抛例外则要越来越窄。
throws
和try
…
catch
经常配合使用,把异常传递给最能处理此异常的方法中,体现各
司其职的特点。
Java
中处理异常方式
消极throws用在方法的声明上
积极try…catch…finally
public static int fn(int b){
try{
return b/2;
}catch(Exception e){
return 0;
}finally{
return b;//返回的结果是一定是b;
}
}
3
(4
)throw
抛出异常
打个比方:
public void eat() throws FoodException{//自定义FoodException是以下异常的父类
if(没有食物) throw new NoFoodException(“呵呵,没有食物”);
if(发现苍蝇) throw new FoundFlyException(“哎呀,发现半只苍蝇”);
}
比较throw
和throws
:
throw
是一个语句,它出现在方法体中,用来抛出异常对象。
throws
是出现在方法声明中,表示本方法中会有异常对象向上(调用者)抛出。
throws
后写的是异常类型; throw
后写的是要抛出的异常对象。
(5
)异常处理流程
try…catch…finally,如果遇到return和System.exit()语句:
一如果在finally之前遇到System.exit()则finally语句不再执行,这是finally不被执行
的唯一情况。因为java.lang.System类的静态方法exit()用于终止当前的Java虚拟机进程。exit()
的参数表示程序终止时的状态码,0表示正常终止,非0表示异常终止。
二return语句用于退出本方法。如果在try或者catch代码块中遇到return语句时,若
有finally语句块,会先执行finally代码块。
三不要在finally代码块中使用return语句。因为这样会导致两种潜在错误:A.覆盖了
try或catch块中的return语句; B.导致丢失异常。
try{
①
②
③
} catch(XxxException e){
④
} finally{
⑤
}
⑥
情况一:没有异常,处理顺序为①②③⑤⑥
情况二:在②处有异常,①②④⑤⑥
情况三:有异常,没有被捕获,①②⑤终止
情况四:如果③后有return语句,①②③⑤
情况五:如果遇到System.exit(),则⑤不执行
允许的处理方式:
① try…catch()
② try…finally//与throws配合使用
③ try…catch…finally
④ try…catch(){} catch(){}…//配多个catch
//注意范围大的异常要写在后面
4
(6
)异常处理规则:
①只有在异常情况下才使用异常处理机制;
②保证操作要么一起成功,要么一起失败;
③ try代码块不要太大;
④ catch子句中指定具体的异常类型;
⑤早抛出,晚捕获。
3
文章到此结束,如果本次分享的java为什么 会编译时异常和java编译异常有哪几个的问题解决了您的问题,那么我们由衷的感到高兴!