美文网首页
Ⅵ.异常处理

Ⅵ.异常处理

作者: 唐騦忆 | 来源:发表于2020-02-27 17:30 被阅读0次

    1. 常见异常

    ParseException 解析异常,日期字符串转换为日期对象的时候,有可能抛出的异常
    OutOfIndexException 数组下标越界异常
    OutOfMemoryError 内存不足
    ClassCastException 类型转换异常
    ArithmeticException 除数为零
    NullPointerException 空指针异常

    2. try+catch异常捕捉

    FileNotFoundException e
            try{
                System.out.println("试图打开 d:/LOL.exe");
                new FileInputStream(f);
                System.out.println("成功打开");
            }
            catch(FileNotFoundException e){
                System.out.println("d:/LOL.exe不存在");
                e.printStackTrace();
            }
    
            File f= new File("d:/LOL.exe");
             
    Exception e 
            try{
                System.out.println("试图打开 d:/LOL.exe");
                new FileInputStream(f);
                System.out.println("成功打开");
            }
             
            catch(Exception e){
                System.out.println("d:/LOL.exe不存在");
                e.printStackTrace();
            }
    

    3. 多异常捕捉

            File f = new File("d:/LOL.exe");
    
    方式一
            try {
                System.out.println("试图打开 d:/LOL.exe");
                new FileInputStream(f);
                System.out.println("成功打开");
                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                Date d = sdf.parse("2016-06-03");
            } catch (FileNotFoundException e) {
                System.out.println("d:/LOL.exe不存在");
                e.printStackTrace();
            } catch (ParseException e) {
                System.out.println("日期格式解析错误");
                e.printStackTrace();
            }
    
    方式二
            try {
                System.out.println("试图打开 d:/LOL.exe");
                new FileInputStream(f);
                System.out.println("成功打开");
                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                Date d = sdf.parse("2016-06-03");
            } catch (FileNotFoundException | ParseException e) {
                if (e instanceof FileNotFoundException)
                    System.out.println("d:/LOL.exe不存在");
                if (e instanceof ParseException)
                    System.out.println("日期格式解析错误");
                e.printStackTrace();
            }
    

    4. finally

    无论是否获取到异常,finally中的内容都会执行。

            try{
                System.out.println("试图打开 d:/LOL.exe");
                new FileInputStream(f);
                System.out.println("成功打开");
            }
            catch(FileNotFoundException e){
                System.out.println("d:/LOL.exe不存在");
                e.printStackTrace();
            }
            finally{
                System.out.println("无论文件是否存在, 都会执行的代码");
            }
    

    5. throws

    抛出异常,交给下一级运行。
    下一级也可以继续抛出,交给下下级处理;或者try+catch消化异常。

        public static void main(String[] args) {
            method1();
        }
     
        private static void method1() {
            try {
                method2();
            } catch (FileNotFoundException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
     
        private static void method2() throws FileNotFoundException {
     
            File f = new File("d:/LOL.exe");
     
            System.out.println("试图打开 d:/LOL.exe");
            new FileInputStream(f);
            System.out.println("成功打开");
     
        }
    

    6. throws与throw的区别

    1. throws 出现在方法声明上,而throw通常都出现在方法体内。
    2. throws 表示出现异常的一种可能性,并不一定会发生这些异常;throw则是抛出异常,执行throw则一定抛出了某个异常对象。

    7. 异常分类

    可查异常: CheckedException
    可查异常即必须进行处理的异常,要么try catch住,要么往外抛,谁调用,谁处理,比如 FileNotFoundException
    如果不处理,编译器,就不让你通过

    运行时异常:RuntimeException
    常见运行时异常:
    除数不能为0异常:ArithmeticException
    下标越界异常:ArrayIndexOutOfBoundsException
    空指针异常:NullPointerException
    在编写代码的时候,依然可以使用try catch throws进行处理,与可查异常不同之处在于,即便不进行try catch,也不会有编译错误
    Java之所以会设计运行时异常的原因之一,是因为下标越界,空指针这些运行时异常太过于普遍,如果都需要进行捕捉,代码的可读性就会变得很糟糕。

    错误:Error
    指的是系统级别的异常,通常是内存用光了
    在默认设置下,一般java程序启动的时候,最大可以使用16m的内存
    如例不停的给StringBuffer追加字符,很快就把内存使用光了。抛出OutOfMemoryError
    错误也是不要求强制捕捉的

    运行时异常与非运行时异常的区别:
    运行时异常时不可查异常,不需要对其进行显式的捕捉
    非运行时异常是可查异常,必须要对其进行显式的捕捉,抛出,不然编译器会报错不允许程序运行.

    8. Throwable

    Throwable是类,Exception和Error都继承了该类
    所以在捕捉的时候,也可以使用Throwable进行捕捉
    异常分Error和Exception
    Exception里又分运行时异常和可查异常。

            try {
                new FileInputStream(f);
                //使用Throwable进行异常捕捉
            } catch (Throwable t) {
                // TODO Auto-generated catch block
                t.printStackTrace();
            }
    

    在方法声明上,可以直接抛出Throwable这个类,但最好不要这样,因为不方便确定错误类型,不利于后续处理。

    9. 自定义异常

    public class Hero {
        public String name;
        protected float hp;
     
        public void attackHero(Hero h) throws EnemyHeroIsDeadException{
            if(h.hp == 0){
                throw new EnemyHeroIsDeadException(h.name + " 已经挂了,不需要施放技能" );
            }
        }
     
         
        class EnemyHeroIsDeadException extends Exception{
             
            public EnemyHeroIsDeadException(){
                 
            }
            public EnemyHeroIsDeadException(String msg){
                super(msg);
            }
        }
          
        public static void main(String[] args) {
             
            Hero garen =  new Hero();
            garen.name = "盖伦";
            garen.hp = 616;
     
            Hero teemo =  new Hero();
            teemo.name = "提莫";
            teemo.hp = 0;
             
            try {
                garen.attackHero(teemo);
                 
            } catch (EnemyHeroIsDeadException e) {
                // TODO Auto-generated catch block
                System.out.println("异常的具体原因:"+e.getMessage());
                e.printStackTrace();
            }
             
        }
    }
    

    相关文章

      网友评论

          本文标题:Ⅵ.异常处理

          本文链接:https://www.haomeiwen.com/subject/ktajvctx.html