java中的异常 try catch

1.学习异常的原因?
 
    如果没有异常处理机制,那么程序的一点小问题,都会导致【程序终止运行】。实际开发中显然是不可能的,所以异常对于程序来说是非常重要的。
    
2.处理异常的方式:
   A.if结构:

         1。代码量大,代码结构不明显

         2。程序员的大部分精力不是用在流程上,而是“堵漏洞”。
   
         3。遗留一个漏洞,程序依然终止。

   B。异常处理机制:
        try  catch  finally    throw         throws

            异常的捕获         抛出异常       声明异常。


3.异常处理的结构:

   第一种:  try---catch:

       程序正常运行:只走try代码块里的代码;catch块不执行。


       程序发生异常:走try报错前的代码--会产生一个异常对象;

                     异常对象与catch块捕获的异常类型进行对比;

                 如果匹配:执行对应catch块代码;

                 如果不匹配:程序依然终止。 


  第二种:try--catch---catch:

          程序正常运行:只走try代码块里的代码;catch块不执行。


          程序发生异常:走try报错前的代码--会产生一个异常对象;

                     异常对象与catch块捕获的异常类型进行对比;

                 如果匹配:执行对应catch块代码;【只有一个匹配的catch块代码】

                 如果不匹配:程序依然终止。
        

          注意:1.父类的异常类型【必须】在最后一个catch里。
                2.子类的异常类型顺序无关。
                3.最后一个catch块都是存放父类的异常类型。


   第三种:try--catch--catch--finally


         程序正常运行:只走try代码块里的代码;catch块不执行;走finally。


          程序发生异常:走try报错前的代码--》会产生一个异常对象;

                      异常对象与catch块捕获的异常类型进行对比;

                 如果匹配:执行对应catch块代码;【只有一个匹配的catch块代码】
                          ---走finally

                 如果不匹配:程序依然终止。 ---走finally


          【问题:什么情况下,finally不走】

               1.return :finally代码块依然执行;
                          先执行catch块中return前面的代码;
                          再执行finally块中的代码;
                          最后执行return。

               2.System.exit(1);程序退出。  终止finally块的执行。

4.输出异常信息的形式:
  System.out.println("提示信息");
  System.out.println(e.getMessage());
  e.printStackTrace();

5.throws关键字(声明异常):
    ---作用:我处理不了,你来处理,我告诉你应该注意的事项。


    当你需要告诉调用者,该方法需要注意异常时,使用throws。


    使用:

        1.在方法定义的时候:

        public void 方法名1() throws 异常类型1,异常类型2{

        }

         2.方法调用的时候:两种方法来处理:

           A。使用try--catch进行异常捕获

                        try {
         被调用的方法名1();
   } catch (异常类型1 e) {
    e.printStackTrace();
   } catch (异常类型2 e) {
    e.printStackTrace();
   }finally{

                        }

          B。不处理,继续往上声明异常:

             public void 方法名2()throws 异常类型1,异常类型2{
  被调用的方法名1();
      }

                

6.throw(抛出异常):

 ---不是异常,为了引起调用者重视,手动抛出异常。
  

   使用throw:
        public void setsex(String str){
            if(!str.equals("男")){

                throw new ClassCastException("性别必须为男或者女");

             }else{

                String sex=str;
             }
        }
7.异常分类:

             object

            throwable
   
     error              Exception

                    checked(编译异常)    Running(运行异常)

error :仅靠程序本身无法恢复的严重错误。

Exception:→由java应用程序抛出和处理的非严重错误。

checked:异常必须处理。(不处理,无法运行)

Running:不处理可以,一旦发生异常,程序终止。

8.log4j 开源日志文件:

作用:把异常信息,在一个独立的文件里进行记录或者是输出到控制台。

   步骤:
 1.把log4j-1.2.17.jar 方法项目的lib文件夹下;加载:选中--右键---buil path---add to buil path 

       2.把log4j.properties 放到项目src ,不能放到src外面,或者是src的子目录都不行。
 3.调用:

 创建logger对象:
  public static Logger logger=Logger.getLogger(Test.class);
     在catch块中写记录异常语句:
  logger.debug("提示信息");
  logger.debug(e.getMessage());
     | 
 这里可以是debug,info,warm,error,fatal五个输出级别

  4.刷新项目,出现 jbit.log文件,记录异常信息

posted @ 2018-07-15 16:23  后山人  阅读(693)  评论(0编辑  收藏  举报