java -- 异常处理、Collection、Iterator迭代器、泛型

打印 上一主题 下一主题

主题 1761|帖子 1761|积分 5283

异常处理

Java异常处理的五个关键字:try、catch、finally、throw、throws
抛出异常throw

在编写程序时,我们必须要考虑程序出现问题的情况
当调用方法使用接受到的参数时,首先需要先对参数数据进行合法的判断,数据若不合法,就应该告诉调用者,传递合法的数据进来。这时需要使用抛出异常的方式来告诉调用者
  1. // 使用格式
  2. throw new 异常类名(参数);
复制代码
  1. public static void main(String[] args) {
  2.     int[] arr = {2,4,52,2};
  3.     //根据索引找对应的元素
  4.     int index = 4;
  5.     int element = getElement(arr, index);
  6.     System.out.println(element);
  7.     System.out.println("over");
  8. }
  9.   /*
  10.    * 根据 索引找到数组中对应的元素
  11.    */
  12. public static int getElement(int[] arr,int index){
  13.     //判断  索引是否越界
  14.     if(index<0 || index>arr.length-1){
  15.         /*
  16.              判断条件如果满足,当执行完throw抛出异常对象后,方法已经无法继续运算
  17.              这时就会结束当前方法的执行,并将异常告知给调用者。这时就需要通过异常来解决
  18.               */
  19.         throw new ArrayIndexOutOfBoundsException("索引越界");
  20.     }
  21.     int element = arr[index];
  22.     return element;
  23. }
复制代码
而对于调用者来说有两种方法进行处理:

  • 进行捕获处理
  • 继续讲问题声明出去,使用throws声明处理。
声明异常throws

声明异常:将问题标识出来,报告给调用者。如果方法内通过throw抛出了编译时异常,而没有捕获处理(稍后讲解该方式),那么必须通过throws进行声明,让调用者去处理
关键字throws运用于方法声明之上,用于表示当前方法不处理异常,而是提醒该方法的调用者来处理异常(抛出异常).
声明异常格式:
  1. 修饰符 返回值类型 方法名(参数) throws 异常类名1,异常类名2…{   }
复制代码
声明异常的代码演示:
  1. public static void main(String[] args) throws FileNotFoundException {
  2.         read("a.txt");
  3. }
  4. // 如果定义功能时有问题发生需要报告给调用者。可以通过在方法上使用throws关键字进行声明
  5. public static void read(String path) throws FileNotFoundException {
  6.         if (!path.equals("a.txt")) {//如果不是 a.txt这个文件
  7.         // 我假设  如果不是 a.txt 认为 该文件不存在 是一个错误 也就是异常  throw
  8.         throw new FileNotFoundException("文件不存在");
  9.         }
  10. }
复制代码
throws用于进行异常类的声明,若该方法可能有多种异常情况产生,那么在throws后面可以写多个异常类,用逗号隔开。
  1. public static void main(String[] args) throws IOException {
  2.         read("a.txt");
  3. }
  4. public static void read(String path)throws FileNotFoundException, IOException {
  5.         if (!path.equals("a.txt")) {//如果不是 a.txt这个文件
  6.         // 我假设  如果不是 a.txt 认为 该文件不存在 是一个错误 也就是异常  throw
  7.         throw new FileNotFoundException("文件不存在");
  8.         }
  9.         if (!path.equals("b.txt")) {
  10.                 throw new IOException();
  11.         }
  12. }
复制代码
捕获异常try…catch

如果异常出现的话,会立刻终止程序,所以我们得处理异常:

  • 该方法不处理,而是声明抛出,由该方法的调用者来处理(throws)。
  • 在方法中使用try-catch的语句块来处理异常。
try-catch的方式就是捕获异常。
捕获异常:Java中对异常有针对性的语句进行捕获,可以对出现的异常进行指定方式的处理。
捕获异常语法如下:
  1. try{
  2.      编写可能会出现异常的代码
  3. }catch(异常类型  e){
  4.      处理异常的代码
  5. }
复制代码
演示如下:
  1. public static void main(String[] args) {
  2.         try {// 当产生异常时,必须有处理方式。要么捕获,要么声明。
  3.         read("b.txt");
  4.         } catch (FileNotFoundException e) {// 括号中需要定义什么呢?
  5.         //try中抛出的是什么异常,在括号中就定义什么异常类型
  6.         System.out.println(e);
  7.         }
  8.         System.out.println("over");
  9. }
  10. /*
  11. *
  12. * 我们 当前的这个方法中 有异常  有编译期异常
  13. */
  14. public static void read(String path) throws FileNotFoundException {
  15.         if (!path.equals("a.txt")) {//如果不是 a.txt这个文件
  16.         // 我假设  如果不是 a.txt 认为 该文件不存在 是一个错误 也就是异常  throw
  17.         throw new FileNotFoundException("文件不存在");
  18.         }
  19. }
复制代码
获取异常信息

Throwable类中定义了一些查看方法:
  1. public String getMessage()
  2. // 获取异常的描述信息,原因(提示给用户的时候,就提示错误原因
  3. public String toString()
  4. // 获取异常的类型和异常描述信息(不用)
  5. public void printStackTrace()
  6. //打印异常的跟踪栈信息并输出到控制台
复制代码
finally 代码块

finally:有一些特定的代码无论异常是否发生,都需要执行。另外,因为异常会引发程序跳转,导致有些语句执行不到。而finally就是解决这个问题的,在finally代码块中存放的代码都是一定会被执行的。
  1. // finally不可以单独使用
  2. // 多用于自身需要处理异常,最终还需要关闭资源时
  3. try{
  4. } catch{
  5. } finally{
  6. }
复制代码
自定义异常

异常类如何定义:

  • 自定义一个编译期异常: 自定义类 并继承于java.lang.Exception。
  • 自定义一个运行时期的异常类:自定义类 并继承于java.lang.RuntimeException。
练习
  1. // 自定义异常, 当输入年龄小于0 或 大于200时 抛出异常
  2. class AgeException extends Exception {
  3.     public AgeException() {}
  4.     public AgeException(String message) {
  5.         super(message);
  6.     }
  7. }
  8. class Person {
  9.     int age;
  10.     public void setAge(int age) throws AgeException {
  11.         if (age < 0 || age > 200) {
  12.             throw new AgeException("年龄非法");
  13.         }
  14.         this.age = age;
  15.     }
  16. }
  17. public class customException {
  18.     public static void main(String[] args) throws AgeException {
  19.         Person person = new Person();
  20.         person.setAge(100);
  21.     }
  22. }
复制代码
Collection集合

集合常用类的继承体系


这张图是常用的集合,并非只有这些集合
常用方法


  • public boolean add(E e):  把给定的对象添加到当前集合中 。
  • public void clear() :清空集合中所有的元素。
  • public boolean remove(E e): 把给定的对象在当前集合中删除。
  • public boolean contains(Object obj): 判断当前集合中是否包含给定的对象。
  • public boolean isEmpty(): 判断当前集合是否为空。
  • public int size(): 返回集合中元素的个数。
  • public Object[] toArray(): 把集合中的元素,存储到数组中
  1. public class Demo {
  2.     public static void main(String[] args) {
  3.         Collection<String> col = new ArrayList<>();
  4.         col.add("张三" );
  5.         col.add("李四");
  6.         col.add("王五");
  7.         System.out.println(col);
  8.         // 删除指定元素, 删除成功返回true, 删除失败返回false
  9.         boolean b = col.remove("刘六");
  10.         System.out.println(b);
  11.         System.out.println(col);
  12.         // 判断集合是否包含指定元素
  13.         boolean b2 = col.contains("张三");
  14.         System.out.println(b2);
  15.         // 清空集合中的元素
  16.         // col.clear();
  17.         // System.out.println(col);
  18.         // 判断当前集合是否为空, 长度为0返回true, 否则返回false
  19.         boolean empty = col.isEmpty();
  20.         System.out.println(empty);
  21.         // 返回集合中元素的个数
  22.         System.out.println(col.size());
  23.         // 将集合转换为数组并遍历
  24.         Object[] arr1 = col.toArray();
  25.         for (int i = 0; i < arr1.length; i++) {
  26.             Object obj = arr1[i];
  27.             System.out.println(obj);
  28.         }
  29.         String[] arr2 = col.toArray(new String[col.size()]);
  30.         for (int i = 0; i < arr2.length; i++) {
  31.             System.out.println(arr2[i]);
  32.         }
  33.     }
  34. }
复制代码
Iterator

要遍历Collection集合,除了可以将其转换为数组,还可以获取该集合迭代器完成迭代操作
  1. public Iterator iterator()
  2. // 获取集合对应的迭代器,用来遍历集合中的元素的
  3. // 迭代:即Collection集合元素的通用获取方式
  4. // 在取元素之前先要判断集合中有没有元素
  5. // 如果有,就把这个元素取出来,继续判断,如果还有就再取出来
  6. // 一直把集合中的所有元素全部取出。这种取出方式专业术语称为迭代。
复制代码
常用方法
  1. E next()
  2. // 返回迭代的下一个元素。
  3. boolean hasNext()
  4. // 如果仍有元素可以迭代,则返回 true
  5. void remove()
  6. // 删除当前next指向的元素
复制代码
  1. Iterator<String> it = col.iterator();
  2. while (it.hasNext()) {
  3.     String next = it.next();
  4.     System.out.println(next);
  5.     if (next.equals("王五")) {
  6.     // 当迭代器在迭代的同时, 集合修改了自身的长度
  7.     // 就会抛出 ConcurrentModificationException 并发修改异常
  8.         // col.add("刘六");
  9.         System.out.println(col);
  10.         // 删除当前next指向的元素
  11.         it.remove();
  12.     }
  13. }
复制代码
泛型

[code]/*    泛型        定义泛型            泛型可以定义在 接口/类/方法 上, 将数据类型作为参数传递            泛型接口:                定义实现类时, 直接确定泛型的数据类型                定义实现类时, 不确定泛型的数据类型 实现类也是泛型类 创建实现类对象时 确定数据类型        使用            创建集合 指定集合中元素的类型, 就是在使用泛型        好处            明确集合中元素的数据类型            将运行时异常提前到编译时错误            避免强制类型转换的麻烦    泛型的通配符        ?    泛型的限定        ? extends 类: 上限限定 只能传这个类 及其子类类型        ? extends super 类: 下限限定 只能传这个类 及其父类类型*/public class Demo {    public static void main(String[] args) {        // 创建对象时 确定泛型的类型为Integer        MyClass myClass1 = new MyClass(12);        System.out.println(myClass1.getName());        // 创建对象时 确定泛型的类型为String        MyClass myClass2 = new MyClass("小明");        System.out.println(myClass2.getName());        System.out.println("======================");        // 泛型方法的调用, 调用方法时 确定arg的类型为Integer        myClass1.method(1,12);        // 调用方法时 确定arg的类型为String        myClass1.method(1,"");        System.out.println("========================");        new A().method("张三", 16);        new B().method('四', "18");        System.out.println("=========================");        ArrayList stringArrayList = new ArrayList();        stringArrayList.add("aaa");        stringArrayList.add("nnn");        ArrayList intArrayList = new ArrayList();        intArrayList.add(1);        intArrayList.add(2);        // 定义方法 使两个集合都可以作为参数传入并遍历        show(stringArrayList);        show(intArrayList);        System.out.println("=========================");        ArrayList animals = new ArrayList();        ArrayList cats = new ArrayList();        ArrayList dogs = new ArrayList();        animals.add(new Animal());        animals.add(new Animal());        cats.add(new Cat());        cats.add(new Cat());        dogs.add(new Dog());        dogs.add(new Dog());        show(dogs);        show(cats);        show(animals);    }    // 泛型的通配符    public static void show(ArrayList arrayList){        // 不能使用?作为变量的数据类型, 所以使用Object        for (Object obj: arrayList) {            // 由于是Object类型, 不能调用对应类型的特有方法            System.out.print(obj + " ");        }        System.out.println();    }    // 泛型的限定    public static void show2(ArrayList
继续阅读请点击广告

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

瑞星

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表