如果程序出现了问题,我们没有做任何处理,最终jvm会做出默认的处理,把异常的名称,原因及出现的问题等信息输出在控制台,同时会结束程序。
try {
可能出现问题的代码;
} catch(异常名 变量) {
针对问题的处理;
} finally {
释放资源;
}
try {
可能出现问题的代码;
} catch(异常名 变量) {
针对问题的处理;
}
int a = 10;
int b = 0;
try {
System.out.println(a / b);
} catch (ArithmeticException ae) {
System.out.println("除数不能为0");
}
// 每一个写一个try...catch
/*
一旦try里面出了问题,就会在这里把问题抛出去,然后和catch里面的问题进行匹配,一旦有匹配的,就执行catch里面的处理,然后结束了try...catch,继续执行后面的语句
*/
// 1. 能明确的尽量明确,不要用大的处理
// 2. 平级关系的异常谁前谁后无所谓,如果出现了子父关系,父必须在后面
int a = 10;
int b = 0;
int[] arr = {
1, 2, 3 };
try {
System.out.println(a / b);
System.out.println(arr[3]);
} catch (ArithmeticException ae) {
System.out.println("除数不能为0");
} catch (ArrayIndexOutOfBoundsException e) {
System.out.println("你访问了不该访问的索引");
}
System.out.println("over");
格式:
try{
} catch(异常名1 | 异常名2 | …变量) {
…
}
注意:这个方法虽然简洁,但是也不够好
public String getMessage() // 异常的消息字符串
public String toString() // 返回异常的简单信息描述
// 此对象的类的name(全路径名)
// ": "(冒号和一个空格)
// 调用此对象getLocalizedMessage()方法的结果,默认返回的是getMessage()的内容
printStackTrace()
// 获取异常类名和异常信息,以及异常出现在程序中的位置。返回值void
// 把信息输出在控制台
String s = "2014-11-20";
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
try {
Date d = sdf.parse(s);
// 创建了一个ParseException对象,然后抛出去,和catch里面进行匹配
System.out.println(d);
} catch (ParseException e) {
// ParseException
// e.printStackTrace();
// getMessage()
// System.out.println(e.getMessage());
// Unparseable date: "2014-11-20"
// toString()
// System.out.println(e.toString());
// java.text.ParseException: Unparseable date: "2014-11-20"
e.printStackTrace();
}
System.out.println("over");
// 编译期异常抛出,将来调用者必须处理
// 运行期异常抛出,将来调用者可以不用处理
public static void main(String[] args) {
System.out.println("今天天气很好");
try {
method();
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("但是就是不该有雾霾");
method2();
}
// 运行期异常的抛出
public static void method2() throws ArithmeticException{
int a = 10;
int b = 0;
System.out.println(a/b);
}
// 编译期异常的抛出
// 在方法声明上抛出,是为了告诉调用者,你注意了,我有问题
public static void method() throws ParseException{
String s = "2014-11-20";
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH-mm-ss");
Date d = sdf.parse(s);
System.out.println(d);
}
throws
用在方法声明后面,跟的是异常类名
可以跟多个异常类名,用逗号隔开
表示抛出异常,由该方法的调用者来处理
throws表示出现异常的一种可能性,并不一定会发生这些异常
throw
用在方法体内,跟的是异常对象名
只能抛出一个异常对象名
表示抛出异常,由方法体内的语句处理
throw则是抛出了异常,执行throw则一定抛出了某种异常
java不可能对所有的情况都考虑到,所以,在实际的开发中,
我们可能需要自己定义异常。
而我们自己随意的写一个类,是不能作为异常类来看的,要想你的类是一个异常类,就必须继承自Exception或者RuntimeException
public class MyException extends Exception{
public MyException(){
}
public MyException(String message) {
super(message);
}
}
public class Teacher {
public void check(int score) throws MyException {
if(score>100 || score<0) {
throw new MyException("分数必须在0-100之间");
}else {
System.out.println("分数没有问题");
}
}
}
/*
* 自定义异常测试类
*/
public class StudentDemo {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入学生成绩:");
int score = sc.nextInt();
Teacher t = new Teacher();
try {
t.check(score);
} catch (MyException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public class MyException extends RuntimeException{
}
// Teacher类中,
// 针对MyException继承自RuntimeException
public void check(int score){
if(score>100 || score<0) {
throw new MyException();
}else {
System.out.println("分数没有问题");
}
}
// 只有里面抛出异常
我们要想实现IO的操作,就必须知道硬盘上文件的表现形式。而Java就提供了一个类File供我们使用。
File(String pathname) // 根据一个路径得到File对象
File(String parent,String child)
// 根据一个目录和一个子文件/目录得到File对象
File(File parent,String child)
// 根据一个父File对象和一个子文件/目录得到File对象
// 创建功能:
public boolean createNewFile() // 创建文件
public boolean mkdir() //创建文件夹 如果存在这样的文件夹,就不创建了
public boolean mkdirs() // 创建文件夹,如果父文件夹不存在,会帮你创建出来
// 删除功能
public boolean delete()
/* 注意:
* A:如果你创建文件或者文件夹忘了写盘符路径,那么默认
* 在项目路径下
* B:Java中的删除不走回收站。
* C:要删除一个文件夹,请注意该文件夹内不能包含文件
* 或者文件夹
*/
// 举例
// 删除功能:我要删除a.txt这个文件
File file3 = new File("a.txt");
System.out.println("delete:"+file3.delete());
// 重命名功能:
public boolean renameTo(File dest)
/*
* 如果路径名相同,就是改名
* 如果路径名不同,就是改名并剪切
*
* 路径以盘符开始:绝对路径 c:\\a.txt
* 路径不以盘符开始:相对路径 a.txt
*/
// 判断功能:
public boolean isDirectory() // 判断是否是目录
public boolean isFile() // 判断是否是文件
public boolean exists() // 判断是否存在
public boolean canRead() // 判断是否可读
public boolean canWrite() // 判断是否可写
public boolean isHidden() // 判断是否隐藏
// 获取功能:
public String getAbsolutePath() // 获取绝对路径
public String getPath() // 获取相对路径
public String getName() // 获取名称
public long length() // 获取长度。字节数
public long lastModified() // 获取最后一次的修改时间,毫秒值
// 获取功能
public String[] list() // 获取指定目录下的所有文件或者文件夹的名称数组
public File[] listFiles() // 获取指定目录下的所有文件或者文件夹的File数组
/*
* 判断G:\csinfo\专业\java\code\file目录下是否有后缀名为
* .jpg的文件,如果有,就输出此文件名称
* A:先获取所有的,然后遍历的时候,依次判断,如果满足条件
* 就输出
*/
File file = new File("G:\\csinfo\\专业\\java\\code\\file");
File[] fileArray = file.listFiles();
for(File f:fileArray) {
if(f.isFile()) {
// 是否以.jpg结尾
if(f.getName().endsWith(".jpg")) {
System.out.println(f.getName());
}
}
}
/*
* B:获取的时候就已经是满足条件的了,然后输出即可
*
* 要想实现这个效果,就必须学习一个接口文件名称过滤器
* public String[] list(FilenameFilter filter)
* public File[] listFiles(FilenameFilter filter)
*/
File file = new File("G:\\csinfo\\专业\\java\\code\\file");
String[] strArray = file.list(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
return new File(dir,name).isFile()&&name.endsWith(".jpg");
}
});
for (String s : strArray) {
System.out.println(s);
}