异常处理一般有2种方式,要么捕获异常try-catch,要么抛出异常throws
如果一个方法后面抛出一个运行时期异常(throws RuntimeException),调用者无须处理
如果一个方法后面抛出一个编译时期异常,调用者必须处理,或者抛出或者try-catch;
运行时期的异常一般都不处理,一般是程序逻辑上的错误,比如分母为0作为除数了。。。
注意如果在try里面出现了异常后,try下面的语句就不会执行,回去寻找catch匹配异常处理会,接下来的语句会处理的(也就是在try-catch-finally之后的语句会继续执行)
/*
* 有些时候,我们是可以对异常进行处理的,但是又有些时候,我们根本就没有权限去处理某个异常。
* 或者说,我处理不了,我就不处理了。
* 为了解决出错问题,Java针对这种情况,就提供了另一种处理方案:抛出。
*
* 格式:
* throws 异常类名
* 注意:这个格式必须跟在方法的括号后面。
*
* 注意:
* 尽量不要在main方法上抛出异常。
* 但是我讲课为了方便我就这样做了。
*
* 小结:
* 编译期异常抛出,将来调用者必须处理。
* 运行期异常抛出,将来调用可以不用处理。
*/
凡是RuntimeException及其子类的异常都不处理(不抛出也不捕获),如果真的知道运行时会有异常抛出的话,,那么直接检查修改程序的逻辑就OK!!!
package 异常; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; public class ExceptionDemo { public static void main(String[] args) { System.out.println("调用方法之前"); try { method();// 编译时期异常抛出必须处理 } catch (ParseException e) { e.printStackTrace(); } System.out.println("调用方法1后在调用方法二"); method2(); } public static void method2() throws RuntimeException{ int a = 10; int b = 0; System.out.println("a/b="+a/b);//运行时期异常可以不用处理,如果处理为抛出异常throws,那么调用者也无需必须处理异常 } public static void method() throws ParseException { String string = "2015-05-30"; SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");//会逐步匹配string格式,不对就抛异常 SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//如果string只有2015-05-30,没有后面的,那么会跑异常,因为这个sdf2无法匹配HH:mm:ss Date date = sdf.parse(string); System.out.println("日期格式化:" + date); } }
异常结构图:
error的异常我们程序员不用处理也处理不了,
runtimeexception的运行时期异常我们也无需处理,
其他的就是编译时期的异常我们就要处理了。
以上就是小编为大家带来的浅谈异常结构图、编译期异常和运行期异常的区别的全部内容了,希望对大家有所帮助,多多支持小牛知识库~
本文向大家介绍浅谈java异常处理之空指针异常,包括了浅谈java异常处理之空指针异常的使用技巧和注意事项,需要的朋友参考一下 听老师说,在以后的学习中大部分的异常都是空指针异常。所以抽点打游戏的时间来查询一下什么是空指针异常 一:空指针异常产生的主要原因如下: (1)当一个对象不存在时又调用其方法会产生异常obj.method() // obj对象不存在 (2)当访问或修改一个对象不存在的字段时
本文向大家介绍浅谈java异常处理(父子异常的处理),包括了浅谈java异常处理(父子异常的处理)的使用技巧和注意事项,需要的朋友参考一下 我当初学java异常处理的时候,对于父子异常的处理,我记得几句话“子类方法只能抛出父类方法所抛出的异常或者是其子异常,子类构造器必须要抛出父类构造器的异常或者其父异常”。那个时候还不知道子类方法为什么要这样子抛出异常,后来通过学习《Thinking in Ja
这个测试通过了,因为它得到的是nullpointerexception,但是,显然存在一个带有asserTrue(false)的断言错误,因此我希望它失败。 解决这个问题的最好方法是什么?解决这个问题的方法可能是下面的,但我不知道这是否是正确的方法。 第二次测试如预期的那样失败了。
例如如下代码: SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日"); Date date = sdf.parse("abcd"); 这段代码会抛出ParseException,而它是编译时异常,为什么编译阶段不报错,运行时报错?
当我尝试用命令从终端运行sikuli时 java-jar sikuli-setup.jar
应用程序通常会通过抛出另一个异常来响应异常。 实际上,第一个异常引起第二个异常。 它可以是非常有助于用户知道什么时候一个异常导致另一个异常。 “异常链(Chained Exceptions)”帮助程序员做到这一点。 以下是Throwable中支持异常链的方法和构造函数。 Throwable getCause() Throwable initCause(Throwable) Throwable(St