Java基础19(01)总结IO流,异常try…catch,throws,File类

1:异常(理解)

(1)程序出现的不正常的情况。

(2)异常的体系

Throwable

|--Error 严重问题,我们不处理。

|--Exception

|--RuntimeException 运行期异常,我们需要修正代码

|--非RuntimeException 编译期异常,必须处理的,否则程序编译不通过

package cn.itcast_01;
/*
 * 异常:程序出现了不正常的情况。
 * 
 * 举例:今天天气很好,班长出去旅游。骑着自行车,去山里面呼吸新鲜空气。
 *  问题1:山路塌陷了,班长及时停住了,但是过不去了。严重的问题。
 *  问题2:班长出门推自行车,发现气没了,把气吹起来。出发前就应该检查的问题。
 *  问题3:班长骑着车在山路上惬意的行驶着,山路两边是有小石子的,中间是平坦的水泥路。
 *  一直在平坦的水泥路上行驶是没有任何问题的,但是呢,他偏偏喜欢骑到小石子上,结果爆胎了。旅游的过程中出现的问题。
 *  no zuo no die。
 * 
 * 程序的异常:Throwable
 *  严重问题:Error 我们不处理。这种问题一般都是很严重的,比如说内存溢出。
 *  问题:Exception
 *  编译期问题:不是RuntimeException的异常 必须进行处理的,因为你不处理,编译就不能通过。
 *  运行期问题:RuntimeException 这种问题我们也不处理,因为是你的问题,而且这个问题出现肯定是我们的代码不够严谨,需要修正代码的。
 * 
 * 如何程序出现了问题,我们没有做任何处理,最终jvm会做出默认的处理。
 * 把异常的名称,原因及出现的问题等信息输出在控制台。
 * 同时会结束程序。
 */
public class ExceptionDemo {
 public static void main(String[] args) {
 //第一阶段
 int a = 10;
 // int b = 2;
 int b = 0;
 System.out.println(a / b);
 //第二阶段
 System.out.println("over");
 }
} 

(3)异常的处理:

A:JVM的默认处理

把异常的名称,原因,位置等信息输出在控制台,但是呢程序不能继续执行了。

B:自己处理

a:try...catch...finally

自己编写处理代码,后面的程序可以继续执行

package cn.itcast_02;
/*
 * 我们自己如何处理异常呢?
 * A:try...catch...finally
 * B:throws 抛出
 * 
 * try...catch...finally的处理格式:
 *  try {
 *  可能出现问题的代码;
 *  }catch(异常名 变量) {
 *  针对问题的处理;
 *  }finally {
 *  释放资源;
 *  }
 * 
 * 变形格式:
 *  try {
 *  可能出现问题的代码;
 *  }catch(异常名 变量) {
 *  针对问题的处理;
 *  }
 * 
 * 注意:
 *  A:try里面的代码越少越好
 *  B:catch里面必须有内容,哪怕是给出一个简单的提示
 */
public class ExceptionDemo {
 public static void main(String[] args) {
 // 第一阶段
 int a = 10;
 // int b = 2;
 int b = 0;
 try {
 System.out.println(a / b);
 } catch (ArithmeticException ae) {
 System.out.println("除数不能为0");
 }
 // 第二阶段
 System.out.println("over");
 }
}
package cn.itcast_02;
/*
 * A:一个异常
 * B:二个异常的处理
 *  a:每一个写一个try...catch
 *  b:写一个try,多个catch
 *  try{
 *  ...
 *  }catch(异常类名 变量名) {
 *  ...
 *  }
 *  catch(异常类名 变量名) {
 *  ...
 *  }
 *  ...
 * 
 *  注意事项:
 *  1:能明确的尽量明确,不要用大的来处理。
 *  2:平级关系的异常谁前谁后无所谓,如果出现了子父关系,父必须在后面。
 * 
 * 注意:
 *  一旦try里面出了问题,就会在这里把问题给抛出去,然后和catch里面的问题进行匹配,
 *  一旦有匹配的,就执行catch里面的处理,然后结束了try...catch
 *  继续执行后面的语句。
 */
public class ExceptionDemo2 {
 public static void main(String[] args) {
 // method1();
 // method2();
 // method3();
 method4();
 }
 public static void method4() {
 int a = 10;
 int b = 0;
 int[] arr = { 1, 2, 3 };
 // 爷爷在最后
 try {
 System.out.println(a / b);
 System.out.println(arr[3]);
 System.out.println("这里出现了一个异常,你不太清楚是谁,该怎么办呢?");
 } catch (ArithmeticException e) {
 System.out.println("除数不能为0");
 } catch (ArrayIndexOutOfBoundsException e) {
 System.out.println("你访问了不该的访问的索引");
 } catch (Exception e) {
 System.out.println("出问题了");
 }
 // 爷爷在前面是不可以的
 // try {
 // System.out.println(a / b);
 // System.out.println(arr[3]);
 // System.out.println("这里出现了一个异常,你不太清楚是谁,该怎么办呢?");
 // } catch (Exception e) {
 // System.out.println("出问题了");
 // } catch (ArithmeticException e) {
 // System.out.println("除数不能为0");
 // } catch (ArrayIndexOutOfBoundsException e) {
 // System.out.println("你访问了不该的访问的索引");
 // }
 System.out.println("over");
 }
 // 两个异常的处理
 public static void method3() {
 int a = 10;
 int b = 0;
 int[] arr = { 1, 2, 3 };
 try {
 System.out.println(arr[3]);
 System.out.println(a / b);
 // System.out.println(arr[3]);
 } catch (ArithmeticException e) {
 System.out.println("除数不能为0");
 } catch (ArrayIndexOutOfBoundsException e) {
 System.out.println("你访问了不该的访问的索引");
 }
 System.out.println("over");
 }
 // 两个异常
 public static void method2() {
 int a = 10;
 int b = 0;
 try {
 System.out.println(a / b);
 } catch (ArithmeticException e) {
 System.out.println("除数不能为0");
 }
 int[] arr = { 1, 2, 3 };
 try {
 System.out.println(arr[3]);
 } catch (ArrayIndexOutOfBoundsException e) {
 System.out.println("你访问了不该的访问的索引");
 }
 System.out.println("over");
 }
 // 一个异常
 public static void method1() {
 // 第一阶段
 int a = 10;
 // int b = 2;
 int b = 0;
 try {
 System.out.println(a / b);
 } catch (ArithmeticException ae) {
 System.out.println("除数不能为0");
 }
 // 第二阶段
 System.out.println("over");
 }
}
package cn.itcast_02;
/*
 * JDK7出现了一个新的异常处理方案:
 *  try{
 * 
 *  }catch(异常名1 | 异常名2 | ...  变量 ) {
 *  ...
 *  }
 * 
 *  注意:这个方法虽然简洁,但是也不够好。
 *  A:处理方式是一致的。(实际开发中,好多时候可能就是针对同类型的问题,给出同一个处理)
 * B:多个异常间必须是平级关系。
 */
public class ExceptionDemo3 {
 public static void main(String[] args) {
 method();
 }
 public static void method() {
 int a = 10;
 int b = 0;
 int[] arr = { 1, 2, 3 };
 // try {
 // System.out.println(a / b);
 // System.out.println(arr[3]);
 // System.out.println("这里出现了一个异常,你不太清楚是谁,该怎么办呢?");
 // } catch (ArithmeticException e) {
 // System.out.println("除数不能为0");
 // } catch (ArrayIndexOutOfBoundsException e) {
 // System.out.println("你访问了不该的访问的索引");
 // } catch (Exception e) {
 // System.out.println("出问题了");
 // }
 // JDK7的处理方案
 try {
 System.out.println(a / b);
 System.out.println(arr[3]);
 } catch (ArithmeticException | ArrayIndexOutOfBoundsException e) {
 System.out.println("出问题了");
 }
 System.out.println("over");
 }
}

b.异常中要了解的几个方法

package cn.itcast_04;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/*
 * 在try里面发现问题后,jvm会帮我们生成一个异常对象,然后把这个对象抛出,和catch里面的类进行匹配。
 * 如果该对象是某个类型的,就会执行该catch里面的处理信息。
 * 
 * 异常中要了解的几个方法:
 * public String getMessage():异常的消息字符串 
 * public String toString():返回异常的简单信息描述
 *  此对象的类的 name(全路径名)
 *  ": "(冒号和一个空格) 
 *  调用此对象 getLocalizedMessage()方法的结果 (默认返回的是getMessage()的内容)
 * printStackTrace() 获取异常类名和异常信息,以及异常出现在程序中的位置。返回值void。把信息输出在控制台。
 */
public class ExceptionDemo {
 public static void main(String[] args) {
 String s = "2014-11-20";
 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
 try {
 Date d = sdf.parse(s); // 创建了一个ParseException对象,然后抛出去,和catch里面进行匹配
 System.out.println(d);
 } catch (ParseException e) { // ParseException e = new ParseException();
 // ParseException
 // e.printStackTrace();
 // getMessage()
 // System.out.println(e.getMessage());
 // Unparseable date: "2014-11-20"
 // toString()
 // System.out.println(e.toString());
 // java.text.ParseException: Unparseable date: "2014-11-20"
 e.printStackTrace();
 //跳转到某个指定的页面(index.html)
 }
 System.out.println("over");
 }
}

c:throws

把自己处理不了的,在方法上声明,告诉调用者,这里有问题

package cn.itcast_05;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/*
 * 有些时候,我们是可以对异常进行处理的,但是又有些时候,我们根本就没有权限去处理某个异常。
 * 或者说,我处理不了,我就不处理了。
 * 为了解决出错问题,Java针对这种情况,就提供了另一种处理方案:抛出。
 * 
 * 格式:
 *  throws 异常类名
 *  注意:这个格式必须跟在方法的括号后面。
 * 
 * 注意:
 *  尽量不要在main方法上抛出异常。
 *  但是我讲课为了方便我就这样做了。
 * 
 * 小结:
 *  编译期异常抛出,将来调用者必须处理。
 *  运行期异常抛出,将来调用可以不用处理。
 */
public class ExceptionDemo {
 public static void main(String[] args) {
 System.out.println("今天天气很好");
 try {
 method();
 } catch (ParseException e) {
 e.printStackTrace();
 }
 System.out.println("但是就是不该有雾霾");
 method2();
 }
 // 运行期异常的抛出
 public static void method2() throws ArithmeticException {
 int a = 10;
 int b = 0;
 System.out.println(a / b);
 }
 // 编译期异常的抛出
 // 在方法声明上抛出,是为了告诉调用者,你注意了,我有问题。
 public static void method() throws ParseException {
 String s = "2014-11-20";
 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
 Date d = sdf.parse(s);
 System.out.println(d);
 }
}

(4)面试题

A:编译期异常和运行期异常的区别?

编译期异常 必须要处理的,否则编译不通过

运行期异常 可以不处理,也可以处理

package cn.itcast_03;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/*
 * 编译时异常和运行时异常的区别
 * 编译期异常:Java程序必须显示处理,否则程序就会发生错误,无法通过编译
 * 运行期异常:无需显示处理,也可以和编译时异常一样处理
 */
public class ExceptionDemo {
 public static void main(String[] args) {
 // int a = 10;
 // int b = 0;
 // if (b != 0) {
 // System.out.println(a / b);
 // }
 String s = "2014-11-20";
 // SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
 // Date d = sdf.parse(s);
 try {
 Date d = sdf.parse(s);
 System.out.println(d);
 } catch (ParseException e) {
 // e.printStackTrace();
 System.out.println("解析日期出问题了");
 }
 }
}

B:throw和throws是的区别

throw:

在方法体中,后面跟的是异常对象名,并且只能是一个

throw抛出的是一个异常对象,说明这里肯定有一个异常产生了

throws:

在方法声明上,后面跟的是异常的类名,可以是多个

throws是声明方法有异常,是一种可能性,这个异常并不一定会产生

package cn.itcast_06;
/*
 * throw:如果出现了异常情况,我们可以把该异常抛出,这个时候的抛出的应该是异常的对象。
 * 
 * throws和throw的区别(面试题)
 throws
 用在方法声明后面,跟的是异常类名
 可以跟多个异常类名,用逗号隔开
 表示抛出异常,由该方法的调用者来处理
 throws表示出现异常的一种可能性,并不一定会发生这些异常
 throw
 用在方法体内,跟的是异常对象名
 只能抛出一个异常对象名
 表示抛出异常,由方法体内的语句处理
 throw则是抛出了异常,执行throw则一定抛出了某种异常
 */
public class ExceptionDemo {
 public static void main(String[] args) {
 // method();
 try {
 method2();
 } catch (Exception e) {
 e.printStackTrace();
 }
 }
 public static void method() {
 int a = 10;
 int b = 0;
 if (b == 0) {
 throw new ArithmeticException();
 } else {
 System.out.println(a / b);
 }
 }
 public static void method2() throws Exception {
 int a = 10;
 int b = 0;
 if (b == 0) {
 throw new Exception();
 } else {
 System.out.println(a / b);
 }
 }
}

(5)finally关键字及其面试题

A:finally用于释放资源,它的代码永远会执行。特殊情况:在执行到finally之前jvm退出了

package cn.itcast_07;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/*
 * finally:被finally控制的语句体一定会执行
 * 注意:如果在执行到finally之前jvm退出了,就不能执行了。
 * 
 * A:格式
 *  try...catch...finally...
 * B:用于释放资源,在IO流操作和数据库操作中会见到
 */
public class FinallyDemo {
 public static void main(String[] args) {
 String s = "2014-11-20";
 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
 Date d = null;
 try {
 // System.out.println(10 / 0);
 d = sdf.parse(s);
 } catch (ParseException e) {
 e.printStackTrace();
 System.exit(0);
 } finally {
 System.out.println("这里的代码是可以执行的");
 }
 System.out.println(d);
 }
}

B:面试题

a:final,finally,finalize的区别?

b:如果在catch里面有return,请问finally还执行吗?如果执行,在return前还是后

会,前。

实际上在中间。这个上课我们讲过

c:异常处理的变形

 try...catch...finally
 try...catch...
 try...catch...catch...
 try...catch...catch...fianlly
 try...finally
package cn.itcast_07;
/*
 * 面试题:
 * 1:final,finally和finalize的区别
 * final:最终的意思,可以修饰类,成员变量,成员方法
 *  修饰类,类不能被继承
 *  修饰变量,变量是常量
 *  修饰方法,方法不能被重写
 * finally:是异常处理的一部分,用于释放资源。
 *  一般来说,代码肯定会执行,特殊情况:在执行到finally之前jvm退出了
 * finalize:是Object类的一个方法,用于垃圾回收
 * 
 * 2:如果catch里面有return语句,请问finally里面的代码还会执行吗?
 *   如果会,请问是在return前,还是return后。
 *     会。前。
 * 
 *   准确的说,应该是在中间。
 * 
 * 3:try...catch...finally的格式变形
 *  A:try...catch...finally
 *  B:try...catch
 *  C:try...catch...catch...
 *  D:try...catch...catch...finally
 *  E:try...finally
 *  这种做法的目前是为了释放资源。
 */
public class FinallyDemo2 {
 public static void main(String[] args) {
 System.out.println(getInt());
 }
 public static int getInt() {
 int a = 10;
 try {
 System.out.println(a / 0);
 a = 20;
 } catch (ArithmeticException e) {
 a = 30;
 return a;
 /*
  * return a在程序执行到这一步的时候,这里不是return a而是return 30;这个返回路径就形成了。
  * 但是呢,它发现后面还有finally,所以继续执行finally的内容,a=40
  * 再次回到以前的返回路径,继续走return 30;
  */
 } finally {
 a = 40;
 return a;//如果这样结果就是40了。
 }
 // return a;
 }
}

(6)自定义异常

继承自Exception或者RuntimeException,只需要提供无参构造和一个带参构造即可

package cn.itcast_08;
/*
 * java不可能对所有的情况都考虑到,所以,在实际的开发中,我们可能需要自己定义异常。
 * 而我们自己随意的写一个类,是不能作为异常类来看的,要想你的类是一个异常类,就必须继承自Exception或者RuntimeException
 * 
 * 两种方式:
 * A:继承Exception
 * B:继承RuntimeException
 */
public class MyException extends Exception {
 public MyException() {
 }
 public MyException(String message) {
 super(message);
 }
}
// public class MyException extends RuntimeException {
//
// }

原文发布于微信公众号 - Java帮帮(javahelp)

原文发表时间:2016-12-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏java达人

最有价值的50道java面试题(二)

来自骆昊的技术专栏 26、抽象的(abstract)方法是否可同时是静态的(static),是否可同时是本地方法(native),是否可同时被synchron...

323100
来自专栏源哥的专栏

找到java代码中没有被使用的公用方法

最近,我打算对我们项目的代码进行清理,准备把一些没有被使用到的公用方法清理掉,但是我在网络找了一遍,像PMD,Findbugs等静态工具,都只能找到没有被使用的...

19310
来自专栏Java技术分享

JavaBean与内省操作

JavaBean是一种特殊的Java类,主要用于传递数据信息,这种Java类中的方法主要用于访问私有的字段,且方法名符合某种命名规则。

226100
来自专栏余林丰

Effective Java通俗理解(上)

  这篇博客是Java经典书籍《Effective Java(第二版)》的读书笔记,此书共有78条关于编写高质量Java代码的建议,我会试着逐一对其进行更为通俗...

32470
来自专栏无题

Java容器各实现类的底层实现原理概述

Java容器各实现类的底层实现原理概述 ArrayList实现原理要点概括 参考文献:http://zhangshixi.iteye.com/blog/67...

47160
来自专栏Android机器圈

数据结构----线性表顺序和链式结构的使用(c)

PS:在学习数据结构之前,我相信很多博友也都学习过一些语言,比如说java,c语言,c++,web等,我们之前用的一些方法大都是封装好的,就java而言,里面使...

11730
来自专栏Golang语言社区

[Go语言]实现可以枚举的map

在golang-nuts上看到有人问怎么样去枚举一个map。在go语言层面,并不支持支持枚举map,也就是说你不能获得一个枚举器在任意时刻去枚举这个map,只能...

39570
来自专栏Java爬坑系列

【Java入门提高篇】Day19 Java容器类详解(二)Map接口

  上一篇里介绍了容器家族里的大族长——Collection接口,今天来看看容器家族里的二族长——Map接口。

282190
来自专栏cmazxiaoma的架构师之路

你应该会的一道多线程笔试题

33330
来自专栏一个会写诗的程序员的博客

《Kotlin极简教程》第3章 Kotlin语言基础第3章 Kotlin语言基础《Kotlin极简教程》正式上架:参考资料

学习任何东西,都是一个由表及里的过程。学习一门编程语言也一样。对于一门编程语言来说,“表” 就是基本词汇(关键字、标识符等)、句子(表达式)和语法。

15020

扫码关注云+社区

领取腾讯云代金券