异常_File

19.01_异常(异常的概述和分类)

  • A:异常的概述

    • 异常就是Java程序在运行过程中出现的错误。
  • B:异常的分类
    • 通过API查看Throwable
    • Error
      • 服务器宕机,数据库崩溃等
    • Exception

      C:异常的继承体系

    • Throwable
      • Error
      • Exception
        • RuntimeException

19.02_异常(JVM默认是如何处理异常的)

  • A:JVM默认是如何处理异常的

    • main函数收到这个问题时,有两种处理方式:
    • a:自己将该问题处理,然后继续运行
    • b:自己没有针对的处理方式,只有交给调用main的jvm来处理
    • jvm有一个默认的异常处理机制,就将该异常进行处理.
    • 并将该异常的名称,异常的信息.异常出现的位置打印在了控制台上,同时将程序停止运行
  • B:案例演示
    • JVM默认如何处理异常
package com.heima.exception;

public class Demo1_Exception {

    /**
     * * A:JVM默认是如何处理异常的
        * main函数收到这个问题时,有两种处理方式:
        * a:自己将该问题处理,然后继续运行
        * b:自己没有针对的处理方式,只有交给调用main的jvm来处理
        * jvm有一个默认的异常处理机制,就将该异常进行处理.
        * 并将该异常的名称,异常的信息.异常出现的位置打印在了控制台上,同时将程序停止运行
    * B:案例演示
        * JVM默认如何处理异常
     */
    public static void main(String[] args) {
        //demo1();
        Demo d = new Demo();
        int x = d.div(10, 0);
        System.out.println(x);
    }

    public static void demo1() {
        int[] arr = {11,22,33,44,55};
        //arr = null;                   //NullPointerException              空指针异常
        System.out.println(arr[10]);    //ArrayIndexOutOfBoundsException    数组索引越界异常
    }

}

class Demo {
    /*
     * 除法运算
     */
    public int div(int a,int b) {       //a = 10,b = 0
        return a / b;                   // 10 / 0  被除数是10,除数是0当除数是0的时候违背了算数运算法则,抛出异常
                                        //返回一个异常对象,new ArithmeticException("/ by zero");
    }
}

19.03_异常(try…catch的方式处理异常1)

  • A:异常处理的两种方式

    • a:try…catch…finally

      • try catch
      • try catch finally
      • try finally
    • b:throws
  • B:try…catch处理异常的基本格式
    • try…catch…finally
  • C:案例演示
    • try…catch的方式处理1个异常

将通过try…catch将问题处理了,程序会继续执行。

19.04_异常(try…catch的方式处理异常2)

  • A:案例演示

    • try…catch的方式处理多个异常
    • JDK7以后处理多个异常的方式及注意事项
package com.heima.exception;

public class Demo3_Exception {

    /**
     * * A:案例演示
     * try...catch的方式处理多个异常
     * JDK7以后处理多个异常的方式及注意事项
     *
     * 安卓,客户端开发,如何处理异常?try{}catch(Exception e){}
     * ee,服务端开发,一般都是底层开发,从底层向上抛
     *
     * try后面如果跟多个catch,那么小的异常放前面,大的异常放后面,根据多态的原理,如果大的放前面,就会将所有的子类对象接收
     * 后面的catch就没有意义了
     */
    public static void main(String[] args) {
        //demo1();
        int a = 10;
        int b = 0;
        int[] arr = {11,22,33,44,55};

        //JDK7如何处理多个异常
        try {
            System.out.println(a / b);
            System.out.println(arr[10]);
        } catch (ArithmeticException | ArrayIndexOutOfBoundsException e) {
            System.out.println("出错了");
        }
    }

    public static void demo1() {
        int a = 10;
        int b = 0;
        int[] arr = {11,22,33,44,55};

        try {
            System.out.println(a / b);
            System.out.println(arr[10]);
            arr = null;
            System.out.println(arr[0]);
        }  catch (Exception e) {                //Exception e = new NullPointerException();
            System.out.println("出错了");
        }

        System.out.println("over");
    }

}

19.05_异常(编译期异常和运行期异常的区别)

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

    • Java中的异常被分为两大类:编译时异常和运行时异常。
    • 所有的RuntimeException类及其子类的实例被称为运行时异常,其他的异常就是编译时异常
    • 编译时异常
      • Java程序必须显示处理,否则程序就会发生错误,无法通过编译
    • 运行时异常
      • 无需显示处理,也可以和编译时异常一样处理
  • B:案例演示
    • 编译期异常和运行期异常的区别

19.06_异常(Throwable的几个常见方法)

  • A:Throwable的几个常见方法

    • a:getMessage()

      • 获取异常信息,返回字符串。
    • b:toString()
      • 获取异常类名和异常信息,返回字符串。
    • c:printStackTrace()
      • 获取异常类名和异常信息,以及异常出现在程序中的位置。返回值void。jvm默认使用这种处理异常
  • B:案例演示
    • Throwable的几个常见方法的基本使用

19.07_异常(throws的方式处理异常)

  • A:throws的方式处理异常

    • 定义功能方法时,需要把出现的问题暴露出来让调用者去处理。
    • 那么就通过throws在方法上标识。
  • B:案例演示
    • 举例分别演示编译时异常和运行时异常的抛出

编译时异常的抛出必须处理

运行时异常的抛出可以处理也可以不处理

package com.heima.exception;

public class Demo6_Exception {

    /**
     * * A:throws的方式处理异常
            * 定义功能方法时,需要把出现的问题暴露出来让调用者去处理。
            * 那么就通过throws在方法上标识。
        * B:案例演示
            * 举例分别演示编译时异常和运行时异常的抛出
            * 编译时异常的抛出必须对其进行处理
            * 运行时异常的抛出可以处理也可以不处理
     * @throws Exception
     */
    public static void main(String[] args) throws Exception {
        Person p = new Person();
        p.setAge(-17);
        System.out.println(p.getAge());
    }

}

class Person {
    private String name;
    private int age;
    public Person() {
        super();

    }
    public Person(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    // 编译时异常的抛出必须对其进行处理,必须写throws,编译有错时就处理
    public void setAge(int age) throws AgeOutOfBoundsException {
        if(age >0 && age <= 150) {
            this.age = age;
        }else {
            throw new Exception("年龄非法");
        }
    }
    //运行时异常的抛出可以处理也可以不处理,不必写throws
    public void setAge(int age) {
        if(age >0 && age <= 150) {
            this.age = age;
        }else {
            throw new RuntimeException("年龄非法");
        }
    }
}

19.08_异常(throw的概述以及和throws的区别)

  • A:throw的概述

    • 在功能方法内部出现某种情况,程序不能继续运行,需要进行跳转时,就用throw把异常对象抛出。
  • B:案例演示
    • 分别演示编译时异常对象和运行时异常对象的抛出
  • C:throws和throw的区别
    • a:throws

      • 用在方法声明后面,跟的是异常类名
      • 可以跟多个异常类名,用逗号隔开
      • 表示抛出异常,由该方法的调用者来处理
    • b:throw
      • 用在方法体内,跟的是异常对象名
      • 只能抛出一个异常对象名
      • 表示抛出异常,由方法体内的语句处理

19.09_异常(finally关键字的特点及作用)

  • A:finally的特点

    • 被finally控制的语句体一定会执行。即使catch里面有return,则也要在执行完finally()之后,再被彻底返回
    • 特殊情况:在执行到finally之前jvm退出了(比如System.exit(0))
  • B:finally的作用
    • 用于释放资源,在IO流操作和数据库操作中会见到
  • C:案例演示
    • finally关键字的特点及作用

19.10_异常(finally关键字的面试题)

  • A:面试题1

    • final,finally和finalize的区别

A:面试题1

* final,finally和finalize的区别

* final可以修饰类,不能被继承

* 修饰方法,不能被重写

* 修饰变量,只能赋值一次

*

* finally是try语句中的一个语句体,不能单独使用,用来释放资源

*

* finalize是一个方法,当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。

  • B:面试题2

    • 如果catch里面有return语句,请问finally的代码还会执行吗?如果会,请问是在return前还是return后。答:在return后。return之后,建议了一个返回路径,继续执行finally()
package com.heima.test;

public class Test1 {

    /**
            * 如果catch里面有return语句,请问finally的代码还会执行吗?如果会,请问是在return前还是return后。答:在return后
     */
    public static void main(String[] args) {
        Demo d = new Demo();
        System.out.println(d.method());
    }
}

class Demo {
    public int method() {
        int x = 10;
        try {
            x = 20;
            System.out.println(1/0);
            return x;
        } catch (Exception e) {
            x = 30;
            return x;
        } finally {
            x = 40;
            //return x;                 千万不要在finally里面写返回语句,因为finally的作用是为了释放资源,是肯定会执行的
                                        //如果在这里面写返回语句,那么try和catch的结果都会被改变,所以这么写就是犯罪
        }
    }
}
//答案:30

19.11_异常(自定义异常概述和基本使用)

  • A:为什么需要自定义异常

    • 举例:人的年龄

      *通过名字区别到底是什么异常

  • B:自定义异常概述
    • 继承自Exception
    • 继承自RuntimeException
  • C:案例演示
    • 自定义异常的基本使用
package com.hongwei.exception;

public class Demo1_Test {

    public static void main(String[] args) throws Exception {
        Person p = new Person();
        p.setAge(-19);
    }
}
class Person{
    private String name;
    private int age;

    public Person(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public Person() {
        super();

    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) throws AgeOutOfBoundsException{
        if(age>=0&&age<=150){
            this.age=age;
        }else{
            throw new AgeOutOfBoundsException("年龄非法");
        }
    }
}
//自定义异常,通过名字区别到底是什么异常
class AgeOutOfBoundsException extends Exception{
    public AgeOutOfBoundsException() {
        super();
    }
    public AgeOutOfBoundsException(String message) {
        super(message);
    }
}

19.12_异常(异常的注意事项及如何使用异常处理)

  • A:异常注意事项

    • a:子类重写父类方法时,子类的方法必须抛出相同的异常或父类异常的子类。(父亲坏了,儿子不能比父亲更坏)
    • b:如果父类抛出了多个异常,子类重写父类时,只能抛出相同的异常或者是他的子集,子类不能抛出父类没有的异常
    • c:如果被重写的方法没有异常抛出,那么子类的方法绝对不可以抛出异常,如果子类方法内有异常发生,那么子类只能try,不能throws
  • B:如何使用异常处理
    • 原则:如果该功能内部可以将问题处理,用try,如果处理不了,交由调用者处理,这是用throws
    • 区别:
      • 后续程序需要继续运行就try
      • 后续程序不需要继续运行就throws
    • 如果JDK没有提供对应的异常,需要自定义异常。

19.13_异常(练习)

  • 键盘录入一个int类型的整数,对其求二进制表现形式

    • 如果录入的整数过大,给予提示,录入的整数过大请重新录入一个整数BigInteger
    • 如果录入的是小数,给予提示,录入的是小数,请重新录入一个整数
    • 如果录入的是其他字符,给予提示,录入的是非法字符,请重新录入一个整数
public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while(true){
            System.out.println("请输入一个整数:");
            String line = sc.nextLine();
            try {
                int num = Integer.parseInt(line);
                System.out.println("我输入的整数是"+num);
                break;
            } catch (Exception e) {
                try {
                    new BigInteger(line);   //能存进来,说明是过大整数;否则抛异常
                    System.out.println("录入错误,您录入的是一个过大整数,请重新输入一个整数:");
                } catch (Exception e1) {
                    try {
                        new BigDecimal(line);
                        System.out.println("录入错误,您录入的是一个小数,请重新输入一个整数:");
                    } catch (Exception e2) {
                        System.out.println("录入错误,您录入的是非法字符,请重新输入一个整数:");
                    }
                }
            }
        }
    }

19.14_File类(File类的概述和构造方法)

  • A:File类的概述

    • File更应该叫做一个路径

      • 文件路径或者文件夹路径
      • 路径分为绝对路径和相对路径
      • 绝对路径是一个固定的路径,从盘符开始
      • 相对路径相对于某个位置,在eclipse下是指当前项目下,在dos下
    • 查看API指的是当前路径
    • 文件和目录路径名的抽象表示形式
  • B:构造方法
    • File(String pathname):根据一个路径得到File对象
    • File(String parent, String child):根据一个目录和一个子文件/目录得到File对象
    • File(File parent, String child):根据一个父File对象和一个子文件/目录得到File对象
  • C:案例演示
    • File类的构造方法
public static void main(String[] args) {
        File file = new File("D:/comeonononononononnonononon/视频/day19.zip");
        File file1 = new File("D:\\comeonononononononnonononon\\视频\\day19.zip");
        System.out.println(file.exists());
        System.out.println(file1.exists());

        File file2 = new File("xxx.txt");   //相对于项目路径
        System.out.println(file2.exists()); //true

        //根据一个目录和一个子文件/目录得到File对象
        String parent = "D:/comeonononononononnonononon/视频";
        String child = "day19.zip";
        File file21 = new File(parent,child);
        System.out.println(file21.exists());

        //根据一个父File对象和一个子文件/目录得到File对象
        File parent3 = new File("D:/comeonononononononnonononon/视频");
        String child3 = "day19.zip";
        File file3 = new File(parent3,child3);
        System.out.println(file3.exists());
        System.out.println(parent3.exists());
    }

###19.15_File类(File类的创建功能)
* A:创建功能
    * public boolean createNewFile():创建文件 如果存在这样的文件,就不创建了
    * public boolean mkdir():创建文件夹 如果存在这样的文件夹,就不创建了
    * public boolean mkdirs():创建文件夹,如果父文件夹不存在,会帮你创建出来
* B:案例演示
    * File类的创建功能

    * 注意事项:
        * 如果你创建文件或者文件夹忘了写盘符路径,那么,默认在项目路径下。

19.16_File类(File类的重命名和删除功能)

  • A:重命名和删除功能

    • public boolean renameTo(File dest):把文件重命名为指定的文件路径
    • public boolean delete():删除文件或者文件夹
  • B:重命名注意事项
    • 如果路径名相同,就是改名。
    • 如果路径名不同,就是改名并剪切。
  • C:删除注意事项:
    • Java中的删除不走回收站。
    • 要删除一个文件夹,请注意该文件夹内不能包含文件或者文件夹
package com.hongwei.File;

import java.io.File;
import java.io.IOException;

public class Demo2_File {
    public static void main(String[] args) throws IOException {
        File file = new File("yyy.txt");
        System.out.println(file.createNewFile());   //创建文件,若已存在,则不创建

        File file1 = new File("ccc");
        System.out.println(file1.mkdir());          //创建文件夹,若已存在,则不创建

        File file2 = new File("aaa\\ccc");
        System.out.println(file2.mkdirs());         //创建多层文件夹,若已存在,则不创建

        File file3 = new File("xxx.txt");
        System.out.println(file3.delete());         //删除文件

        File file4 = new File("ccc");
        System.out.println(file4.delete());         //删除文件夹

        File file5 = new File("aaa");
        System.out.println(file5.delete());         //删除文件夹,若文件夹下有其他文件,则不操作
    }
}

19.17_File类(File类的判断功能)

  • A:判断功能

    • public boolean isDirectory():判断是否是目录
    • public boolean isFile():判断是否是文件
    • public boolean exists():判断是否存在
    • public boolean canRead():判断是否可读
    • public boolean canWrite():判断是否可写
    • public boolean isHidden():判断是否隐藏
  • B:案例演示
    • File类的判断功能
public static void main(String[] args) {
        File file = new File("aaa");
        System.out.println(file.isDirectory());     //判断是否为文件夹

        File file1 = new File("yyy.txt");
        System.out.println(file1.isFile());         //判断是否为文件

        File file2 = new File("yyy.txt");
        file2.setReadable(false);
        System.out.println(file2.canRead());        //windows系统认为所有文件都是可读的
        file2.setWritable(false);
        System.out.println(file2.canWrite());       //windows系统可以设置文件不可写

        System.out.println(file2.isHidden());       //判断文件是否隐藏
    }

19.18_File类(File类的获取功能)

  • A:获取功能

    • public String getAbsolutePath():获取绝对路径
    • public String getPath():获取路径
    • public String getName():获取名称
    • public long length():获取长度。字节数
    • public long lastModified():获取最后一次的修改时间,毫秒值
    • public String[] list():获取指定目录下的所有文件或者文件夹的名称数组
    • public File[] listFiles():获取指定目录下的所有文件或者文件夹的File数组
  • B:案例演示
    • File类的获取功能
public static void main(String[] args) throws IOException {
        File file = new File("yyy.txt");
        System.out.println(file.getAbsolutePath());     //得到绝对路径
        System.out.println(file.getPath());             //获取构造方法中传递的路径
        System.out.println(file.getName());             //得到文件夹的名字
        System.out.println(file.length());              //当前文件下文件字节

        System.out.println(file.lastModified());        //最后一次修改时间,毫秒值
        Date date = new Date(file.lastModified());
        SimpleDateFormat sdf = new SimpleDateFormat("YYYY年MM月dd日 HH:mm:ss");
        System.out.println(sdf.format(date));

        File file1 = new File("aaa");
        for (String string : file1.list()) {            //获取指定文件夹下所有文件(当前级别下)的名称数组
            System.out.print(string+" ");
        }
        System.out.println();
        for(File f : file1.listFiles()){                //获取指定文件夹下所有文件(当前级别下)的File数组
            System.out.println(f);                      //输出文件全路径(File重写了toString())
        }
    }

19.19_File类(输出指定目录下指定后缀的文件名)

  • A:案例演示

    • 需求:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
File file1 = new File("D:\\comeonononononononnonononon\\视频\\day19\\code\\day19");
        File[] fileList = file1.listFiles();
        for (File file2 : fileList) {
            if(file2.isFile() && file2.getName().endsWith(".txt")){
                System.out.println(file2);
            }
        }

19.20_File类(文件名称过滤器的概述及使用)

  • A:文件名称过滤器的概述

    • public String[] list(FilenameFilter filter)
    • public File[] listFiles(FileFilter filter)
  • B:文件名称过滤器的使用
    • 需求:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
  • C:源码分析
    • 带文件名称过滤器的list()方法的源码
File file = new File("D:\\comeonononononononnonononon\\视频\\day19\\code\\day19");
String[] arr = file.list(new FilenameFilter() {

    @Override
    public boolean accept(File dir, String name) {
        File f = new File(dir,name);
        return f.isFile() && f.getName().endsWith(".txt");
            }
});
for (String string : arr) {
    System.out.println(string);
}

19.21_File类(递归)

  • 5的阶乘

19.22_day19总结

把今天的知识点总结一遍。

时间: 2024-11-07 11:38:44

异常_File的相关文章

路径名导致的异常:javax.imageio.IIOException: Can&#39;t read input file!

背景: 写了一个测试程序,目的是读取本地的图片,为其打上水印图片.在使用过程中总会遇到:javax.imageio.IIOException: Can't read input file!的错误,最开始以为是图片路径名称写的不对,按照网上的提示换成正斜线和反斜线都不行.后来发现问题的原因是:图片的路径中不能有点(英文点:.); 具体的错误异常提示如下: javax.imageio.IIOException: Can't read input file! at javax.imageio.Imag

Java_IO流_File类配合使用(其中用到了递归)

第一:Java File类的功能非常强大,利用Java基本上可以对文件进行所有的操作.以下对Java File文件操作以及常用方法进行简单介绍 案例1:遍历出指定目录下的文件夹,并输出文件名 1 static void findDirectory() { 2 //构建file对象,指定目录路径(separator 跨平台分隔符) 3 File root = new File("E://") ;//传的是String,因为是路径,所有按照格式写eg:"E://"与&q

使用 IDEA 创建 Maven Web 项目 (异常)- Disconnected from the target VM, address: &#39;127.0.0.1:59770&#39;, transport: &#39;socket&#39;

运行环境: JDK 版本:1.8 Maven 版本:apache-maven-3.3.3 IDEA 版本:14 maven-jetty-plugin 配置: <plugin> <groupId>org.eclipse.jetty</groupId> <artifactId>jetty-maven-plugin</artifactId> <configuration> <webAppSourceDirectory>${pro

mybaits非配置原因,导致SqlSession was not registered for synchronization异常

今天运行程序时报了 SqlSession [[email protected]] was not registered for synchronization because synchronization is not active [11:03:17]-Closing non transactional SqlSession [[email protected]] 由于异常是集中处理的,所以报了这样的错误,查了半天,网上结果都是说配置文件出错的,可是我的项目配置文件肯定是没错的,因为项目都开

异常笔记--java编程思想

开一个新的系列,主要记一些琐碎的重要的知识点,把书读薄才是目的...特点: 代码少,概念多... 1. 基本概念 异常是在当前环境下无法获得必要的信息来解决这个问题,所以就需要从当前环境跳出,就是抛出异常.抛出异常后发生的几件事: 1.在堆上创建异常对象. 2.当前的执行路径中止                                          3. 当前环境抛出异常对象的引用.                                         4. 异常处理机制接

爱上MVC~业务层刻意抛出异常,全局异常的捕获它并按格式返回

对于业务层的程序的致命错误,我们一直的做法就是直接抛出指定的异常,让程序去终断,这种做法是对的,因为如果一个业务出现了致命的阻塞的问题,就没有必要再向上一层一层的返回了,但这时有个问题,直接抛异常,意味着服务器直接500了,前端如何去显示,或者如果你是API的服务,如果为前端返回,如果是500,那直接就挂了,哈哈! 下面是在MVC环境下优化的全局异常捕获代码(非API) /// <summary> /// 全局异常捕获 /// </summary> public class Glo

Laravel 5.4 中的异常处理器和HTTP异常处理实例教程

错误和异常是处理程序开发中不可回避的议题,在本地开发中我们往往希望能捕获程序抛出的异常并将其显示打印出来,以便直观的知道程序在哪里出了问题并予以解决,而在线上环境我们不希望将程序错误或异常显示在浏览器中(出于安全考虑),这个时候我们仍然要捕获异常,只不过不是显示到浏览器中,而是记录到日志中,方便日后排查问题. 百牛信息技术bainiu.ltd整理发布于博客园 Laravel当然支持PHP原生的错误和异常处理,但是在此基础上进行了一些封装处理,从而更方便在不同开发环境切换以及对错误和异常的处理.

Java必知必会:异常机制详解

一.Java异常概述 在Java中,所有的事件都能由类描述,Java中的异常就是由java.lang包下的异常类描述的. 1.Throwable(可抛出):异常类的最终父类,它有两个子类,Error与Exception. Throwable中常用方法有: getCause():返回抛出异常的原因.如果 cause 不存在或未知,则返回 null. getMeage():返回异常的消息信息. printStackTrace():对象的堆栈跟踪输出至错误输出流,作为字段 System.err 的值.

python 异常和弹出框

import tkinter.messagebox try: fileContent = open("abnormal.txt") fileContent.close() print("over") #把异常消息赋予一个"ex"变量 except Exception as ex: print(ex) tkinter.messagebox.showinfo("Alert",ex) tkinter.messagebox.askye