1.1 IO流概述(理解)
A:IO流概述
IO流用来处理设备之间的数据传输
上传文件和下载文件
B:IO流前奏
讲解IO流之前为什么先讲解异常和File类呢?
因为File表示的是IO流将来要操作的文件,所以我们需要学习File类。
而常见操作文件无非就是上传文件和下载文件,在这个操作的过程中可能出现问题,
出现问题后,我们需要对对应的代码进行处理。所以我们需要学习异常。
1.2 异常的概异常的概述: (理解)
异常就是Java程序在运行过程中出现的错误。
B:异常的分类: 举例:张三骑自行车旅游
C:异常的继承体系
异常的基类: Throwable
严重问题: Error 不予处理,因为这种问题一般是很严重的问题,比如: 内存溢出
非严重问题: Exception
编译时异常: 非RuntimeException
运行时异常: RuntimeException述和分类
1.3JVM默认是如何处理异常的
A:JVM默认是如何处理异常的
main函数收到这个问题时,有两种处理方式:
a:自己将该问题处理,然后继续运行
b:自己没有针对的处理方式,只有交给调用main的jvm来处理
jvm有一个默认的异常处理机制,就将该异常进行处理.
并将该异常的名称,异常的信息.异常出现的位置打印在了控制台上,同时将程序停止运行
B:案例演示: 1 / 0 ; JVM默认如何处理异常
1.3.1 try…catch的方式处理异常1
异常处理的两种方式
a:try…catch…finally
b:throws
try...catch处理异常的基本格式
try {
可能出现问题的代码 ;
}catch(异常名 变量名){
针对问题的处理 ;
}finally{
释放资源;
}
1.3.2 try…catch的方式处理异常2
注意事项:1:能明确的尽量明确,不要用大的来处理。
2:平级关系的异常谁前谁后无所谓,如果出现了子父关系,父必须在后面。
try {
可能出现问题的代码 ;
}catch(异常名1 变量名1){
对异常的处理方式 ;
}catch (异常名2 变量名2){
对异常的处理方式 ;
}…
JDK7针对多个异常的处理方案
注意事项:
好处: 就是简化了代码
弊端: 对多个异常的处理方式是一致的
多个异常之间只能是平级的关系,不能出现子父类的继承关系
1.4编译期异常和运行期异常的区别
A:编译期异常和运行期异常的区别
Java中的异常被分为两大类:编译时异常和运行时异常。
所有的RuntimeException类及其子类的实例被称为运行时异常,其他的异常就是编译时异常
编译时异常: Java程序必须显示处理,否则程序就会发生错误,无法通过编译
运行时异常: 无需显示处理,也可以和编译时异常一样处理
IO流(Throwable的几个常见方法(理解)
A:Throwable的几个常见方法
a:getMessage(): 获取异常信息,返回字符串。
b:toString(): 获取异常类名和异常信息,返回字符串。
c:printStackTrace(): 获取异常类名和异常信息,以及异常出现在程序中的位置。返回值void。
1.5 throws的方式处理异常
A:throws的方式处理异常
定义功能方法时,需要把出现的问题暴露出来让调用者去处理。
那么就通过throws在方法上标识。
B:案例演示
举例分别演示编译时异常和运行时异常的抛出
1.6 throw的概述以及和throws的区别
A:throw的概述: 在功能方法内部出现某种情况,程序不能继续运行,需要进行跳转时,就用throw 把异常对象抛出。
B:throws和throw的区别
a:throws
用在方法声明后面,跟的是异常类名
可以跟多个异常类名,用逗号隔开
表示抛出异常,由该方法的调用者来处理
throws表示出现异常的一种可能性,并不一定会发生这些异常
b:throw
用在方法体内,跟的是异常对象名
只能抛出一个异常对象名
这个异常对象可以是编译期异常对象,可以是运行期异常对象
表示抛出异常,由方法体内的语句处理
throw则是抛出了异常,执行throw则一定抛出了某种异常
2.1 finally关键字的面试题
finally { 最终的 ,不管你try里面有没有遇到异常,他里面的代码都会执行
我们一般会在这里做一些善后工作,比如释放资源
//final,finally和finalize的区别
//final 修饰类 不能被继承 修饰变量,变为常量 修饰方法,方法不能被重写
//finally 用在异常处理语句当中
//finalize() Object finalize()
// 当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。
public class MyTest3 {
public static void main(String[] args) {
//一般在main方法里面,就不要再抛出了,自己捕获处理
Scanner scanner = null;
try {
String strDate = "2019-07-20";
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
dateFormat.parse(strDate);
//System.out.println(1 / 0);
scanner = new Scanner(System.in);
int i = scanner.nextInt();
} catch (Exception e) {
e.printStackTrace();
} finally {
System.out.println("finally里面的代码必须执行");
if(scanner!=null){
scanner.close();
}
}
}
}
2.2 自定义异常概述和基本使用
A:为什么需要自定义异常:
因为在以后的开发过程中,我们可能会遇到各种问题,
而Jdk不可能针对每一种问题都给出具体的异常类与之对应.
为了满足需求,我们就需要自定义异常.
案例演示:
if(score > 100 || score < 0){
// 抛出一个异常对象
//注意 自定义异常类 提供有参数构造
throw new MyException("成绩不在有效的范围内(0~100)....") ;
}else {
System.out.println("成绩合法.....................");
}
2.3 自定义异常练习
***//自定义创建异常***
public class NoMoneyException extends RuntimeException {
public NoMoneyException(String S) {super(S); }
}
-----------------------
public class MyDemo {
public static void main(String[] args) {
int money=1000;
Scanner scanner = new Scanner(System.in);
System.out.println("请输入你的取款金额 ");
int inputMoney= scanner.nextInt();
if(inputMoney<=money){
money-=inputMoney;
System.out.println("取款成功");
}else{
throw new NoMoneyException("余额不足异常");
}
}
}
3.1 File类的概述和构造方法
File类的概述
查看API
文件和目录路径名的抽象表示形式
这个File类可以用来表示文件,也可以用来表示目录
构造方法
File(String pathname):根据一个路径得到File对象
File(String parent, String child):根据一个目录和一个子文件/目录得到File对象
File(File parent, String child):根据一个父File对象和一个子文件/目录得到File对象
3.1.1 File类的创建功能
A:创建功能
public boolean createNewFile():创建一个新的文件 如果存在这样的文件,就不创建了
public boolean mkdir():创建文件夹 如果存在这样的文件夹,就不创建了 注意这个方法只能创建单层目录 如果创建多层目录得一层一层创建
public boolean mkdirs():创建文件夹,如果父文件夹不存在,会帮你创建出来 可以创建多层目录 当然也可以创建单层目录
注意事项:如果你创建文件或者文件夹忘了写盘符路径,那么,默认在项目路径下。
相对路径:没有带盘符的路径
绝对路径:带有盘符的路径
3.1.2 File类的删除功能
删除功能
public boolean delete():删除文件或者文件夹
注意:删除文件夹时 这个文件夹是空文件夹 如果这个文件夹里面有文件,则不能删除
注意事项:Java中的删除不走回收站。要删除一个文件夹,请注意该文件夹内不能包含文件或者文件夹
3.1.3 File类的重命名功能
renameTo:
重命名功能
public boolean renameTo(File dest):把文件重命名为指定的文件路
注意事项:
如果路径名相同,就是改名。
如果路径名不同,就是改名并剪切。
3.1.4 File类的获取功能
获取功能
public String getAbsolutePath(): 获取绝对路径
public String getPath(): 获取相对路径
public String getParent() 返回此抽象路径名父目录的路径名字符串;如果此路径名没有指定父目录,则返回 null。
public File getParentFile() 返回此抽象路径名父目录的抽象路径名;如果此路径名没有指定父目录,则返回 null。
public long getTotalSpace() 返回此抽象路径名指定的分区大小。 返回总容量 单位字节
public long getFreeSpace() 返回此抽象路径名指定的分区中未分配的字节数。返回剩余容量 单位字节
public String getName(): 获取名称
public long length(): 获取长度。字节数
public long lastModified(): 获取最后一次的修改时间,毫秒值
public String[] list(): 获取指定目录下的所有文件或者文件夹的名称数组
public File[] listFiles(): 获取指定目录下的所有文件或者文件夹的File数组
3.1.5 File类的判断功能
判断功能
public boolean isDirectory(): 判断是否是目录
public boolean isFile(): 判断是否是文件
public boolean exists(): 判断是否存在
public boolean canRead(): 判断是否可读
public boolean canWrite(): 判断是否可写
public boolean isHidden(): 判断是否隐藏
public boolean isAbsolute(); 判断是否使用的是绝对路径
4.1输出指定目录下指定后缀的文件名
分析:
a: 把E:\demo这个路径封装成一个File对象
b: 获取该路径下所有的文件或者文件夹对应的File数组
c: 遍历这个数组,进行判断
public class MyTest {
public static void main(String[] args) {
// public String[] list (): 获取该目录下所有的文件或文件夹的名称
File file = new File("E:\\测试图片");
String[] list = file.list();
for (String s : list) {
System.out.println(s);
}
}
}
------------------------
4.2 文件名称过滤器的概述及使用
文件名称过滤器的概述
public String[] list(FilenameFilter filter)
public File[] listFiles(FilenameFilter filter)
B:文件名称过滤器的使用: 需求:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
案例演示:
public class MyTest3 {
public static void main(String[] args) {
// A:
// 案例演示:
// 需求:判断E\\测试图片 目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
File file = new File("E:\\测试图片");
//思路:1.该目录下的所有文件或文件夹获取到
//2.遍历这个文件数组,判断他是不是文件,还要判断,他的后缀名,是.jpg结尾的
File[] files = file.listFiles();
for (File f : files) {
if(f.isFile()&&f.getName().endsWith(".jpg")){
System.out.println(f.getName());
}
}
}
}