JavaSE——异常(2/2)-异常的处理(记录异常并提示 、尝试重新修复)

简介: JavaSE——异常(2/2)-异常的处理(记录异常并提示 、尝试重新修复)

开发中对于异常的常见处理方式

  • 一层一层往上抛出异常,并且在最上层捕获异常,分为两种不同的处理方式。

 

例如,B站网页报错就是采取的第一种方式:


记录异常并提示

案例演示

先来看第一种处理方式,以时间解析报错和读取不存在文件为例子。



如上方案例,我们来进行处理:

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.util.Date;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
 
public class Test3 {
    //写一个方法是时间解析错误的,且去调用另外一个方法two()
    public static void one() throws ParseException, FileNotFoundException {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date d = sdf.parse("2028-11-11 10:24");
        System.out.println(d);
        two();
    }
 
    //two方法也报了异常
    public static void two() throws FileNotFoundException {
        //读取文件,暂时只需要知道他读取了不存在的文件而报错,其他先不了解
        InputStream is = new FileInputStream("D:/wuyu/ok.png");
    }
 
    public static void main(String[] args) {
        try {
            one();
        } catch (ParseException e) {
            System.out.println("您要解析的时间有问题了!");
            e.printStackTrace();        //打印出这个异常对象的信息,记录下来
        } catch (FileNotFoundException e) {
            System.out.println("您要找的文件不存在!");
            e.printStackTrace();        //打印出这个异常对象的信息,记录下来
        }
    }
}

运行结果:


如果时间格式无误,就会捕获到two方法的异常了


再次运行:


流程解析



对于文件读取错误的异常,流程也是类似的


写法优化

它们都是Exception的子类,所以可以直接抛出Exception

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.util.Date;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
 
public class Test3 {
    public static void main(String[] args) {
        try {
            one();
        } catch (Exception e) {
            System.out.println("您当前操作有问题!");
            e.printStackTrace();        //打印出这个异常对象的信息,记录下来
        }
    }
 
    //写一个方法是时间解析错误的,且去调用另外一个方法two()
    public static void one() throws Exception {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date d = sdf.parse("2028-11-11 12:10:24");
        System.out.println(d);
        two();
    }
 
    //two方法也报了异常
    public static void two() throws Exception {
        //读取文件,暂时只需要知道他读取了不存在的文件而报错,其他先不了解
        InputStream is = new FileInputStream("D:/wuyu/ok.png");
    }
}

运行之后也能达到同样的效果:


尝试重新修复

第二种方法,我们以完成一个需求演示

需求:调用一个方法,让用户输入一个合适的价格返回为止。

import java.util.Scanner;
 
public class Test4 {
    //需求:调用一个方法,让用户输入一个合适的价格返回为止。
    public static double getMoney(){
        Scanner sc = new Scanner(System.in);
        double money = 0;
        while(true){
            System.out.println("请您输入合适的价格: ");
            money = sc.nextDouble();
            if(money >= 0){
                return money;
            }else{
                System.out.println("您输入的价格是不合适的");
            }
        }
    }
    public static void main(String[] args) {
        //对于上述的方法,如果输入的是非double类型的数据,就会产生异常
 
        //我们对异常尝试修复
        while(true){
            try {
                System.out.println(getMoney());
                break;
            } catch (Exception e) {
                System.out.println("请您输入合法的数字!");
            }
        }
 
    }
}

看运行结果:



抛出异常(throws)

  • 在方法上使用throws关键字,可以将方法内部出现的异常抛出去给调用者处理。

/推荐方式

方法 throws Exception{

}

//Exception代表可以捕获一切异常

捕获异常(try...catch)

  • 直接捕获程序出现的异常。

//推荐方式

try{

       //可能出现异常的代码

}catch(Exception e){

       e.printStackTrace();        //直接打印异常对象的信息

}

//Exception代表可以捕获一切异常


END



目录
相关文章
|
消息中间件 运维 负载均衡
【Kafka】Kafka 实现负载均衡与故障转移
【4月更文挑战第5天】【Kafka】Kafka 实现负载均衡与故障转移
|
存储 SQL NoSQL
NoSQL数据库
NoSQL数据库
381 4
|
负载均衡 算法 微服务
常见的微服务流量治理策略
常见的微服务流量治理策略
793 3
|
SQL Java 关系型数据库
【Java】已解决Java中的com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException异常
【Java】已解决Java中的com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException异常
1333 0
|
前端开发 关系型数据库 MySQL
Windows 安装 MySQL 8.1 (图文教程)
Windows 安装 MySQL 8.1 (图文教程)
|
消息中间件 Java Kafka
Apache Kafka-初体验Kafka(02)-Centos7下搭建单节点kafka_配置参数详解_基本命令实操
Apache Kafka-初体验Kafka(02)-Centos7下搭建单节点kafka_配置参数详解_基本命令实操
262 0
|
编解码 并行计算 Ubuntu
尝鲜Ubuntu22.04 下 PaddlePaddle-GPU安装踩坑记
尝鲜Ubuntu22.04 下 PaddlePaddle-GPU安装踩坑记
4188 1
尝鲜Ubuntu22.04 下 PaddlePaddle-GPU安装踩坑记
|
SQL 弹性计算 Cloud Native
分布式事务 GTS 的价值和原理浅析
GTS 今年双 11 的成绩 今年 2684 亿的背后,有一个默默支撑,低调到几乎被遗忘的中间件云产品——GTS(全局事务服务,Global Transaction Service),稳稳地通过了自 2014 年诞生以来的第 5 次“大考”。
4463 87
分布式事务 GTS 的价值和原理浅析
|
存储 SQL 分布式计算
|
Prometheus Kubernetes 监控
Kubernetes 各组件日志清理
今天看到k8s的nodeexport pod failed,看到是磁盘空间压力过高。
871 0