19.01_异常(异常的概述和分类)
- A:异常的概述:异常就是Java程序在运行过程中出现的错误。
- B:异常的分类
- 通过API查看
Throwable
类,Throwable
类是 Java 语言中所有错误或异常的超类。有2个子类:Error
、Exception
.
- 通过API查看
- C:异常的继承体系
-Throwable
-Error
-Exception
-RuntimeException (这个异常,一般是由程序员犯的错误引起的)
19.02_JVM默认是如何处理异常的
- main函数收到这个问题时,有两种处理方式:
- a:自己将该问题处理,然后继续运行
- b:自己没有针对的处理方式,只有交给调用main的jvm来处理
- jvm有一个默认的异常处理机制,就将该异常进行处理.
- 并将该异常的名称,异常的信息.异常出现的位置打印在了控制台上,同时将程序停止运行
19.03_异常(try...catch的方式处理异常1)
try
:用来检测异常
catch
:用来捕获异常
finally
:释放资源
三种搭配方式
try catch
try catch finally
try finally
19.04_异常(try...catch的方式处理异常2)
try {
....
} catch (ArithmeticException e) {
....
} catch (Exception e) {
....
}
try后面如果跟多个catch,那么小的异常放前面,大的异常放后面,根据多态原理,如果大的放前面,就会将所有的子类对象异常接收,后面的catch就没有意义了。
JDK7新增异常处理方法:
try {
....
} catch (ArithmeticException | ArrayStoreException e) {
这里可以同时处理 多个类型的异常
}
19.05_编译期异常和运行期异常的区别
Java中的异常被分为两大类:编译时异常和运行时异常。
所有的
RuntimeException
类及其子类的实例被称为运行时异常,其他的异常就是编译时异常-
编译时异常
- Java程序必须显示处理,否则程序就会发生错误,无法通过编译
-
运行时异常
- 无需显示处理,也可以和编译时异常一样处理
19.06_Throwable的几个常见方法
Throwable
的几个常见方法
try {
System.out.println(10 / 0);
} catch (Exception e) {
System.out.println(e.getMessage()); // 获取异常信息,返回字符串。
System.out.println(e.toString()); // 获取异常类名和异常信息,返回字符串
e.printStackTrace(); //JVM默认就使用这种方式处理异常
}
19.07_throws的方式处理异常
-
throws
的方式处理异常- 定义功能方法时,需要把出现的问题暴露出来让调用者去处理。
- 那么就通过
throws
在方法上标识。
public static void setAge(int age) throws Exception {
if (age > 0 && age <= 150) {
System.out.println("年龄是: " + age);
} else {
throw new Exception("年龄非法"); //注意这里的异常类型
}
}
抛出异常情况:
编译时异常: 必须对其进行处理。
运行时异常: 可以处理也可以不处理。
19.08_throw的概述以及和throws的区别
- A:throw的概述
- 在功能方法内部出现某种情况,程序不能继续运行,需要进行跳转时,就用throw把异常对象抛出。
throws和throw的区别
- a:
throws
- 用在方法声明后面,跟的是异常类名
- 可以跟多个异常类名,用逗号隔开
- 表示抛出异常,由该方法的调用者来处理
- b:
throw
- 用在方法体内,跟的是异常对象名
- 只能抛出一个异常对象名
- 表示抛出异常,由方法体内的语句处理
19.09_finally关键字的特点及作用
- A:finally的特点
- 被
finally
控制的语句体一定会执行,就算catch
里面有return
,也会被执行。 - 特殊情况:在执行到
finally
之前jvm退出了(比如System.exit(0)
)
- 被
- B:
finally
的作用- 用于释放资源,在IO流操作和数据库操作中会见到
19.10_异常(finally关键字的面试题)
-
final
,finally
和finalize
的区别
final 可以修饰类,类就不能被继承
修饰方法,方法不能被重写
修饰变量,变量只能赋值一次
finally 是try语句中的一个语句体,不能单独使用,用来释放资源
finalize() 是一个方法:
当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。
- 如果
catch
里面有return
语句,请问finally
的代码还会执行吗?如果会,请问是在return
前还是return
后?
答: 执行,return前
public int method() {
int x = 10;
try {
x = 20;
System.out.println( 12/0 );
return x;
} catch (Exception e){
x = 30 ;
return x;
} finally { //顺便提一句:千万不要在finally里写return语句,这里仅仅做释放语句
x = 40 ;
}
}
// 请问上述程序,返回多少? (答案是30,因为return关键字执行时,就把返回值返回了,再执行
finally时,仅仅是把x值改变了,但是30已经被返回了)
19.11_自定义异常概述和基本使用
- A:为什么需要自定义异常 : 为了见名知意。
- B:自定义异常概述
- 继承自
Exception
- 继承自
RuntimeException
然后再重写构造方法即可。
- 继承自
19.12_异常的注意事项及如何使用异常处理
- A:异常注意事项
- a:子类重写父类方法时,子类的方法必须抛出相同的异常或父类异常的子类。(父亲坏了,儿子不能比父亲更坏)
- b:如果父类抛出了多个异常,子类重写父类时,只能抛出相同的异常或者是他的子集,子类不能抛出父类没有的异常
- c:如果被重写的方法没有异常抛出,那么子类的方法绝对不可以抛出异常,如果子类方法内有异常发生,那么子类只能try,不能throws
- B:如何使用异常处理
原则:如果该功能内部可以将问题处理,用try,如果处理不了,交由调用者处理,这是用throws
-
区别:
- 后续程序需要继续运行就try
- 后续程序不需要继续运行就throws
如果JDK没有提供对应的异常,需要自定义异常。
19.13_异常(练习)
- 键盘录入一个int类型的整数,对其求二进制表现形式
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个整数:");
while (true) {
String str = sc.nextLine();
try {
int num = Integer.parseInt(str);
System.out.println("二进制是: " + Integer.toBinaryString(num));
break ;
} catch (Exception e1) {
try {
new BigInteger(str); //如果录入是一个很大的整数,这句就不会报错
System.out.println("录入整数过大...请重新录入...");
} catch (Exception e2) {
try {
new BigDecimal(str); //如果录入是小数,这句就不会报错
System.out.println("录入的是小数...请重新录入...");
} catch (Exception e) {
System.out.println("录入的不是整数...请重新录入...");
}
}
}
}
sc.close();
19.14_File类的概述和构造方法
-
File更应该叫做一个路径
- 文件路径或者文件夹路径
- 路径分为绝对路径和相对路径
- 绝对路径是一个固定的路径,从盘符开始
- 相对路径相对于某个位置,在eclipse下是指当前项目下,在dos下
- 查看API指的是当前路径
- 文件和目录路径名的抽象表示形式
B:构造方法
File(String pathname):根据一个路径得到File对象
File(String parent, String child):根据一个目录和一个子文件/目录得到File对象
File(File parent, String child):根据一个父File对象和一个子文件/目录得到File对象
19.15_File类的创建功能
File file = new File("xxoo.txt");
System.out.println(file.createNewFile()); //创建文件
File f2 = new File("XXOO");
System.out.println(f2.mkdir()); //创建文件夹
File f3 = new File("PP//WW"); //这里写成 \\ 或者 / 或者 // 都是可以的
System.out.println(f3.mkdirs()); //创建多级文件夹
如果你创建文件或者文件夹忘了写盘符路径,那么,默认在项目路径下
以上都是如果存在,就不创建了。
19.16_File类的重命名和删除功能
public boolean renameTo(File dest):把文件重命名为指定的文件路径
public boolean delete():删除文件或者文件夹
重命名注意事项
-如果路径名相同,就是改名。
-如果路径名不同,就是改名并剪切。
删除注意事项:
-Java中的删除不走回收站。
-要删除一个文件夹,请注意该文件夹内不能包含文件或者文件夹
19.17_File类的判断功能
public boolean isDirectory() :判断是否是目录
public boolean isFile() :判断是否是文件
public boolean exists() :判断是否存在
public boolean canRead() :判断是否可读
public boolean canWrite() :判断是否可写
public boolean isHidden() :判断是否隐藏
public boolean setReadable(boolean readable) //设置是否可读
public boolean setWritable(boolean writable) //设置是否可写
注意在 Windows系统下,一切文件都是可读的。所以win下设置是否可读无效。
19.18_File类的获取功能
public String getAbsolutePath():获取绝对路径
public String getPath():获取路径
public String getName():获取名称
public long length():获取长度。字节数
public long lastModified():获取最后一次的修改时间,毫秒值
public String[] list():获取指定目录下的所有文件或者文件夹的名称数组
public File[] listFiles():获取指定目录下的所有文件或者文件夹的File数组
File file = new File("xxoo.txt");
Date d = new Date(file.lastModified()); //最后一次修改时间,毫秒值
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
System.out.println(df.format(d));
19.19_输出指定目录下指定后缀的文件名
- 需求:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
File[] files = new File("E:\\QQVipDownload").listFiles();
for (File f : files) {
if (f.isFile() && f.getName().endsWith(".exe")) {
System.out.println(f);
}
}
19.20_文件名称过滤器的概述及使用
public String[] list(FilenameFilter filter)
public File[] listFiles(FileFilter filter)
需求:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
File f2 = new File("E:\\QQVipDownload");
File[] arr = f2.listFiles(new FilenameFilter() { //文件名称过滤器
@Override
public boolean accept(File dir, String name) {
File f = new File(dir, name);
return (f.isFile() && f.getName().endsWith(".exe"));
}
});
for (File file : arr) {
System.out.println(file);
}
最好看看源码: 带文件名称过滤器的list()方法的源码
END。
我是小侯爷。
在魔都艰苦奋斗,白天是上班族,晚上是知识服务工作者。
如果读完觉得有收获的话,记得关注和点赞哦。
非要打赏的话,我也是不会拒绝的。