###18.01_异常(异常的概述和分类)
* A:异常的概述
* 异常就是Java程序在运行过程中出现的错误。
* B:异常的分类
* 通过API查看Throwable
* Error(错误:一出现就是致命的)
* 服务器宕机,数据库崩溃等
* Exception
C:异常的继承体系
* Throwable
* Error
* Exception
* RuntimeException(运行时异常,一般都是程序员犯得错误,需要修改源码的.)
* 编译时异常:在编译时必须进行处理,不处理无法通过编译.
案例:
public class Demo1_Exception {
public static void main(String[] args) {
//demo1();
}
//运行时报出NullPointException(空指针异常)和ArrayIndexOutOfBoundsException
public static void demo1() {
int[] arr = {11,22,33,44,55};
//arr = null; //NullPointerException 空指针异常
System.out.println(arr[10]); //ArrayIndexOutOfBoundsException 数组索引越界异常
}
###18.02_异常(JVM默认是如何处理异常的)
* A:JVM默认是如何处理异常的
* main函数收到这个问题时,有两种处理方式:
* a:自己将该问题处理,然后继续运行
* b:自己没有针对的处理方式,只有交给调用main的jvm来处理
* jvm有一个默认的异常处理机制,就将该异常进行处理.
* 并将该异常的名称,异常的信息.异常出现的位置打印在了控制台上,同时将程序停止运行
* B:案例演示
* JVM默认如何处理异常
案例:
public class Demo1_Exception {
public static void main(String[] args) {
Demo d = new Demo();
int x = d.div(10, 0);
System.out.println(x);
}
}
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");
}
}
###18.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个异常
案例:
public class Demo2_Exception {
/**
try:用来检测异常的
catch:用来捕获异常的
finally:释放资源
世界上最真情的相依就是你在try我在catch,无论你发神马脾气,我都静静接受,默默处理(try打印结果,catch默默处理)
当通过trycatch将问题处理了,程序会继续执行
*/
public static void main(String[] args) {
Demo2 d = new Demo2();
try{
int x = d.div(10, 0);
System.out.println(x);
}catch(ArithmeticException a) { //ArithmeticException a = new ArithmeticException();
System.out.println("出错了,除数为零了");
}
System.out.println("1111111111111111");
}
}
class Demo2 {
/*
* 除法运算
*/
public int div(int a,int b) { //a = 10,b = 0
return a / b; // 10 / 0 被除数是10,除数是0当除数是0的时候违背了算数运算法则,抛出异常
//new ArithmeticException("/ by zero");
}
}
###18.04_异常(try...catch的方式处理异常2)
* A:案例演示
* try...catch的方式处理多个异常
* JDK7以后处理多个异常的方式及注意事项
案例:
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 (ArithmeticException e) {
System.out.println("除数不能为零");
} catch (ArrayIndexOutOfBoundsException e) {
System.out.println("索引越界了");
} catch (Exception e) { //Exception e = new NullPointerException();
System.out.println("出错了");
}
System.out.println("over");
}
}
###18.05_异常(编译期异常和运行期异常的区别)
* A:编译期异常和运行期异常的区别
* Java中的异常被分为两大类:编译时异常和运行时异常。
* 所有的RuntimeException类及其子类的实例被称为运行时异常,其他的异常就是编译时异常
* 编译时异常(未雨绸缪异常)
* Java程序必须显示处理,否则程序就会发生错误,无法通过编译
* 运行时异常
* 无需显示处理,也可以和编译时异常一样处理
*是程序员自身犯的错误,需要回来修改代码(明明知道a/b,除数不能为0,你还得让a/0进行运算,明明知道数组的长度为5,还非得去索引为5的元素)
* B:案例演示
* 编译期异常和运行期异常的区别
案例:
import java.io.FileInputStream;
public class Demo4_Exception {
/**
编译时异常也叫做未雨绸缪异常
未雨绸缪:在做某些事情的时候要做某些准备
编译时异常:在编译某个程序的时候,有可能会有这样那样的事情发生,比如文件找不到,这样的异常就必须在编译的时候处理
如果不处理编译通不过
运行时异常:就是程序员所犯得错误,需要回来修改代码
*/
public static void main(String[] args) {
try {
//用fis输入流读取文件,但是xxx.txt文件在硬盘上,要去硬盘上读取,所以硬盘上的文件很可能是不存在的,
//如果不存在,fis去读取此文件时,就出错了,所以万一读不到xxx.txt,我对它进行处理就可以,即try-catch
FileInputStream fis = new FileInputStream("xxx.txt");
} catch(Exception e) {
}
}
}
###18.06_异常(Throwable的几个常见方法)
* A:Throwable的几个常见方法
* a:getMessage()
* 获取异常信息,返回字符串。
* b:toString()
* 获取异常类名和异常信息,返回字符串。
* c:printStackTrace()
* 获取异常类名和异常信息,以及异常出现在程序中的位置。返回值void。
* B:案例演示
* Throwable的几个常见方法的基本使用
案例:
public class Demo5_Throwable {
public static void main(String[] args) {
try {
System.out.println(1/0);
} catch (Exception e) { //Exception e = new ArithmeticException("/ by zero");
//System.out.println(e.getMessage()); //获取异常信息
//System.out.println(e); //调用toString方法,相当于(toString e)打印异常类名和异常信息
e.printStackTrace();
//jvm默认就用这种方式处理异常
}
}
}
###18.07_异常(throws的方式处理异常)
* A:throws的方式处理异常
* 定义功能方法时,需要把出现的问题暴露出来让调用者去处理。
* 那么就通过throws在方法上标识。
* B:案例演示
* 举例分别演示编译时异常和运行时异常的抛出
/*声明异常是在方法后用throws异常类名(声名这个方法可能抛出的异常)
抛出异常 是在方法内部throw异常对象(如果在方法内部抛出了一个编异时期异常,那么必须在方法上声明)
捕获异常try{}catch(){};*/
案例:
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;
}
public void setAge(int age) throws Exception {
if(age >0 && age <= 150) {
this.age = age;
}else {
Exception e = new Exception("年龄非法");
throw e;
throw new Eexception(“年龄历非法”);
}
}
}
###18.08_异常(throw的概述以及和throws的区别)
* A:throw的概述
* 在功能方法内部出现某种情况,程序不能继续运行,需要进行跳转时,就用throw把异常对象抛出。
* B:案例演示
* 分别演示编译时异常对象和运行时异常对象的抛出
* C:throws和throw的区别
* throws
* 用在方法声明后面,跟的是异常类名,可以跟多个异常类名,用逗号隔开
* 表示抛出异常,由该方法的调用者来处理
public void setAge(int age) throws Exception
* throw
* 用在方法体内,跟的是异常对象名,只能抛出一个异常对象名
* 表示抛出异常,由方法体内的语句处理
Exception e = new Exception("年龄非法");
throw e;
throw new Eexception(“年龄历非法”)
###18.09_异常(finally关键字的特点及作用)
* A:finally的特点(最终的)
* 被finally控制的语句体一定会执行
* 特殊情况:在执行到finally之前jvm退出了(比如System.exit(0))
* B:finally的作用
* 用于释放资源,在IO流操作和数据库操作中会见到
* C:案例演示
* finally关键字的特点及作用
案例:
public class Demo7_Finally {
/**
*return语句相当于是方法的最后一口气,那么在他将死之前会看一看有没有finally帮其完成遗愿,如果有就将finally执行
*后在彻底返回
*/
public static void main(String[] args) {
try {
System.out.println(10/0);
} catch (Exception e) {
System.out.println("除数为零了");
//System.exit(0); //退出jvm虚拟机
return;//在执行之前先看看有没有finally,有的话,先执行finally,再执行return
} finally {
System.out.println("看看我执行了吗");
}
}
}
Finally 在Io中很常见一般写的是释放资源的代码
###18.10_异常(finally关键字的面试题)
* A:面试题1
* final,finally和finalize的区别
* B:面试题2
* 如果catch里面有return语句,请问finally的代码还会执行吗?如果会,请问是在return前还是return后。
案例:
public class Test1 {
/**
* * A:面试题1
* final,finally和finalize的区别
* final可以修饰类,不能被继承
* 修饰方法,不能被重写
* 修饰变量,只能赋值一次
*
finally是try语句中的一个语句体,不能单独使用,用来释放资源
finalize是一个方法,当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。
B:面试题2
如果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的结果都会被改变,所以这么写就是犯罪
}
}
}
###18.11_异常(自定义异常概述和基本使用)
* A:为什么需要自定义异常
* 举例:人的年龄
* B:自定义异常概述
* 继承自Exception
* 继承自RuntimeException
* C:案例演示
* 自定义异常的基本使用
案例:
自定义异常类:
public class Demo8_Exception {
/**
* * A:为什么需要自定义异常
* 通过名字区分到底是神马异常,有针对的解决办法
* 举例:人的年龄
* B:自定义异常概述
* 如果是编绎时期异常继承自Exception
* 如果是运行时期异常继承自RuntimeException
* C:案例演示
* 自定义异常的基本使用
*/
public static void main(String[] args) {
}
}
class AgeOutOfBoundsException extends Exception {
public AgeOutOfBoundsException() {
super();
}
public AgeOutOfBoundsException(String message) {
super(message);
}
}
测试类:
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;
}
public void setAge(int age) throws AgeOutOfBoundsException {
if(age >0 && age <= 150) {
this.age = age;
}else {
throw new AgeOutOfBoundsException("年龄非法");
}
}
}
###18.12_异常(异常的注意事项及如何使用异常处理)
* A:异常注意事项
* a:子类重写父类方法时,子类的方法必须抛出相同的异常或父类异常的子类。(父亲坏了,儿子不能比父亲更坏)
* b:如果父类抛出了多个异常,子类重写父类时,只能抛出相同的异常或者是他的子集,子类不能抛出父类没有的异常
* c:如果被重写的方法没有异常抛出,那么子类的方法绝对不可以抛出异常,如果子类方法内有异常发生,那么子类只能try,不能throws
* B:如何使用异常处理
* 原则:如果该功能内部可以将问题处理,用try,如果处理不了,交由调用者处理,这是用throws
* 区别:
* 后续程序需要继续运行就try
* 后续程序不需要继续运行就throws
* 如果JDK没有提供对应的异常,需要自定义异常。
案例:
public class Test6 {
/**
* 程序启动后, 可以从键盘输入接收多个整数, 直到输入quit时结束输入. 把所有输入的整数倒序排列打印.
*
* 1,创建Scanner对象,键盘录入
* 2,创建TreeSet集合对象,TreeSet集合中传入比较器
* 3,无限循环不断接收整数,遇到quit退出,因为退出是quit,所以键盘录入的时候应该都以字符串的形式录入
* 4,判断是quit就退出,不是将其转换为Integer,并添加到集合中
* 5,遍历TreeSet集合并打印每一个元素
*/
public static void main(String[] args) {
//1,创建Scanner对象,键盘录入
Scanner sc = new Scanner(System.in);
//2,创建TreeSet集合对象,TreeSet集合中传入比较器
TreeSet<Integer> ts = new TreeSet<>(new Comparator<Integer>() {
@Override
public int compare(Integer i1, Integer i2) {
//int num = i2 - i1; //自动拆箱
int num = i2.compareTo(i1);
return num == 0 ? 1 : num;
}
});
//3,无限循环不断接收整数,遇到quit退出,因为退出是quit,所以键盘录入的时候应该都以字符串的形式录入
while(true) {
String line = sc.nextLine(); //将键盘录入的字符串存储在line中
if("quit".equals(line)) {
break;
}
//4,判断是quit就退出,不是将其转换为Integer,并添加到集合中
try {
Integer i = Integer.parseInt(line);
ts.add(i);
} catch (Exception e) {
System.out.println("输入错误,请输入一个整数:");
}
}
// 5,遍历TreeSet集合并打印每一个元素
for (Integer integer : ts) {
System.out.println(integer);
}
}
###18.13_异常(练习)
* 键盘录入一个int类型的整数,对其求二进制表现形式
* 如果录入的整数过大,给予提示,录入的整数过大请重新录入一个整数BigInteger
* 如果录入的是小数,给予提示,录入的是小数,请重新录入一个整数
* 如果录入的是其他字符,给予提示,录入的是非法字符,请重新录入一个整数
案例:
public class Test2 {
/**
* 键盘录入一个int类型的整数,对其求二进制表现形式
* 分析:
* 1,创建键盘录入对象
* 2,将键盘录入的结果存储在String类型的字符串中,存储int类型中如果有不符合条件的直接报错,无法进行后续判断
* 3,键盘录入的结果转换成int类型的数据,是正确的还是错误的
* 4,正确的直接转换
* 5,错误的要进行对应判断
*/
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个整数:");
③while(true) {
String line = sc.nextLine(); //将键盘录入的结果存储在line中
②try {
①int num = Integer.parseInt(line); //将字符串转换为整数
System.out.println(Integer.toBinaryString(num));//将整数转换为二进制
break; //跳出循环
}catch(Exception e) {
try {
new BigInteger(line);
System.out.println("录入错误,您录入的是一个过大整数,请重新输入一个整数:");
}catch (Exception e2) { //alt + shif + z (try catch快捷键)
try {
new BigDecimal(line);
System.out.println("录入错误,您录入的是一个小数,请重新输入一个整数:");
} catch (Exception e1) {
System.out.println("录入错误,您录入的是非法字符,请重新输入一个整数:");
}
}
}
}
}
}
//alt + shif + Z (try catch快捷键)
###18.14_File类(File类的概述和构造方法)
* A:File类的概述
* File更应该叫做一个路径
* 文件路径或者文件夹路径
* 路径分为绝对路径和相对路径
* 绝对路径是一个固定的路径,从盘符开始
* 相对路径相对于某个位置,在eclipse下是指当前项目下,在dos下
* 查看API指的是当前路径
* 文件和目录路径名的抽象表示形式
* B:构造方法
* File(String pathname):根据一个路径得到File对象
File file = new File("F:\\test\\001_今日内容.avi");
1, 既可以指向文件也要吧指向文件夹
2, File指向存在与否都可以,不存在不会创建exists
* File(String parent, String child):根据一个目录和一个子文件/目录得到File对象
* File(File parent, String child):根据一个父File对象和一个子文件/目录得到File对象
* C:案例演示
* File类的构造方法
案例
public class Demo1_File {
public static void main(String[] args) {
//demo1();
//demo2();
demo3();
}
private static void demo3() {
File parent = new File("F:\\双元课堂\\day19\\video");
String child = "001_今日内容.avi";
//封装成file对象的好处,可以使用file对象的更多方法
File file = new File(parent, child);
System.out.println(file.exists());
System.out.println(parent.exists());
}
public static void demo2() {
String parent = "F:\\test\\001_今日内容.avi";
String child = "001_今日内容.avi";
File file = new File(parent,child);
System.out.println(file.exists());
}
public static void demo1() {
//File file = new File("XXX.txt");//XXX.txt代表相对路径,相对于当前项目所在的位置
//File file = new File("F:/双元课堂/day19/video/001_今日内容.avi");
File file = new File("F:\\test\\001_今日内容.avi");
System.out.println(file.exists());
//需要在所在项目下建立xxx.txt文件
File file2 = new File("xxx.txt");
System.out.println(file2.exists());
File file3 = new File("yyy.txt");
System.out.println(file3.exists());
}
}
###18.15_File类(File类的创建功能)
* A:创建功能
* public boolean createNewFile():创建文件 如果存在这样的文件,就不创建了
* public boolean mkdir():创建文件夹 如果存在这样的文件夹,就不创建了
* public boolean mkdirs():创建文件夹,如果父文件夹不存在,会帮你创建出来
* B:案例演示
* File类的创建功能
* 注意事项:
1, 如果路径不存在的话不能创建路径的
2,封装File路径时如果盘符在电脑中不存在的话,不能创建文件及文件夹
3
案例:
public class Demo2_FileMethod {
public static void main(String[] args) throws IOException {
//demo1();
demo2();
}
private static void demo2() {
File dir1 = new File("aaa");
System.out.println(dir1.mkdir());
File dir2 = new File("bbb.txt"); //这样写是可以的,文件夹也是可以有后缀的
System.out.println(dir2.mkdir());
File dir3 = new File("ccc\\ddd");
System.out.println(dir3.mkdirs()); //创建多级目录
}
public static void demo1() throws IOException {
File file = new File("yyy.txt");
System.out.println(file.createNewFile()); //如果没有就创建,返回true
File file2 = new File("zzz");
System.out.println(file2.createNewFile());
}
}
###18.16_File类(File类的重命名和删除功能)
* A:重命名和删除功能
* public boolean renameTo(File dest):把文件重命名为指定的文件路径
* public boolean delete():删除文件或者文件夹
* B:重命名注意事项
* 如果路径名相同,就是改名。
* 如果路径名不同,就是改名并剪切。
* C:删除注意事项:
* Java中的删除不走回收站。
* 要删除一个文件夹,请注意该文件夹内不能包含文件或者文件夹
案例:
public class Demo3_FileMethod {
public static void main(String[] args) {
//demo1();
File file1 = new File("yyy.txt");
System.out.println(file1.delete());
File file2 = new File("aaa");
System.out.println(file2.delete());
File file3 = new File("ccc"); //如果删除一个文件夹,那么文件夹必须是空的
System.out.println(file3.delete());
}
public static void demo1() {
File file1 = new File("ooo.txt");
File file2 = new File("D:\\xxx.txt");
System.out.println(file1.renameTo(file2));
}
}
###18.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 class Demo4_FileMethod {
public static void main(String[] args) {
//demo1();
demo2();
}
public static void demo2() {
File file = new File("zzz");
file.setReadable(false);
System.out.println(file.canRead()); //windows系统认为所有的文件都是可读的
file.setWritable(true);
System.out.println(file.canWrite()); //windows系统可以设置为不可写
//现在项目路径下建立aaa.txt,并设置为隐藏
File file2 = new File("aaa.txt");
System.out.println(file2.isHidden()); //判断是否是隐藏文件
System.out.println(file.isHidden());
}
public static void demo1() {
File dir1 = new File("ccc");
System.out.println(dir1.isDirectory()); //判断是否是文件夹
File dir2 = new File("zzz");
System.out.println(dir2.isDirectory());
System.out.println(dir1.isFile()); //判断是否是文件
System.out.println(dir2.isFile());
}
}
###18.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 class Demo5_FileMethod {
public static void main(String[] args) {
//demo1();
demo2();
}
public static void demo2() {
File dir = new File("F:\\test\\001_今日内容.avi");
String[] arr = dir.list(); //仅为了获取文件名
for (String string : arr) {
System.out.println(string);
}
File[] subFiles = dir.listFiles();
for (File file : subFiles) { //获取文件对象
System.out.println(file);
}
}
public static void demo1() {
File file1 = new File("ccc.txt");
File file2 = new File("F:\\test\\001_今日内容.avi");
//System.out.println(file1.getAbsolutePath()); //获取绝对路径
//System.out.println(file2.getAbsolutePath());
//System.out.println(file1.getPath()); //获取构造方法中传入路径
//System.out.println(file2.getPath());
// System.out.println(file1.getName()); //获取文件或者文件的名字
// System.out.println(file2.getName());
//
// System.out.println(file1.length());
Date d = new Date(file1.lastModified()); //文件的最后修改时间
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
System.out.println(sdf.format(d));
}
}
###18.19_File类(输出指定目录下指定后缀的文件名)
* A:案例演示
* 需求:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
案例:
public class Test3 {
public static void main(String[] args) {
File dir = new File("E:\\"); // 可以是\\ 或是/ 来指定目录
// String[] arr = dir.list(); //获取e盘下所有的文件或文件夹
// for (String string : arr) {
// if(string.endsWith(".jpg")) {
// System.out.println(string);
// }
// }
File[] subFiles = dir.listFiles(); //获取e盘下所有的文件或文件夹对象
for (File subFile : subFiles) {
if(subFile.isFile() && subFile.getName().endsWith(".jpg")) {
System.out.println(subFile);
}
}
}
}
###18.20_File类(文件名称过滤器的概述及使用)
* A:文件名称过滤器的概述
* public String[] list(FilenameFilter filter)
* public File[] listFiles(FileFilter filter)
* B:文件名称过滤器的使用
* 需求:判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出该文件名称
* C:源码分析
* 带文件名称过滤器的list()方法的源码
案例:
public class Test3 {
public static void main(String[] args) {
File dir = new File("E:\\");
String[] arr = dir.list(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
//System.out.println(dir);
//System.out.println(name);
File file = new File(dir, name);
return file.isFile() && file.getName().endsWith(".jpg");
}
});
for (String string : arr) {
System.out.println(string);
}
}
}