黑马程序员_java异常概述

深入理解Java异常处理机制
本文详细阐述了Java中异常的概念、类型、处理方法及自定义异常的实现,包括异常的分类、异常处理语句的使用、finally块的作用、异常在子父类覆盖中的体现,以及异常练习案例。
------- android培训java培训、期待与您交流! ----------

异常:就是程序在运行时出现不正常情况。
异常由来:问题也是现实生活中的一个具体的事物,也可以通过java的类的形式进

行描述。并封装成对象。其实就是java对不正常情况进行描述的对象体现。

对于问题的划分:两种:一种是严重的问题,一种是非严重的问题。

对于严重的,java通过Error类进行描述。
对于Error一般不编写针对性的代码对其进行处理。
对于非严重的,java通过Exception类进行描述。
对于Exception一般使用针对性处理方式进行处理。

共性内容
比如:不正常情况的信息,引发原因
抽取出类:
Throwable
Error
Exception

2,异常的处理
java提供了特有的语句进行处理。
try
{
需要被检测的代码;
}
catch(异常类 变量)
{
处理异常的代码;(处理方式)
}
finally
{
一定会执行的语句;
}

3,对捕获到的异常对象进行常见方法操作。
String getMessage();
其实jvm默认的异常处理机制,就是在调用printStackTrace方法。打印异常的堆栈

的跟踪信息。

在函数上声明异常。
便于提高安全性,让调用者进行处理。不处理编译失败。


--------------------------

class Demo
{
int div(int a,int b)
{
  return a/b;
}
}
class ExceptionDemo
{
public static void main(String[] args)
{
  Demo d=new Demo();
  try
  {
   int x=d.div(4,0);
   System.out.println("x="+x);
  }catch(Exception e) //Exception e=new

ArithmeticException();
  {
   System.out.println("除零了"+e);
   System.out.println(e.getMessage());// /by zero;
   System.out.println(e.toString());// 异常名称,异

常信息。
   e.printStackTrace();//异常名称,异常信息,异常出

现的位置。
  }finally
  {
   System.out.println("over");
  }
}
}

-----------------------------
该看9.7
异常声明throws


class Demo
{
int div(int a,int b)throws Exception
{
  return a/b;
}
}
class ExceptionDemo
{
public static void main(String[] args)throws Exception
{
  Demo d=new Demo();

  int x=d.div(4,0);
  System.out.println("x="+x);
  System.out.println("over");
}
}

--------------------------------
对多异常的处理

1,声明异常时,建议声明更为具体的异常。这样处理的可以更具体。
2,对方声明几个异常,就对应有几个catch块。不要定义多余的catch块。
如果多个catch块中的异常出现继承关系,父类异常catch块放在最下面。

建议在进行catch处理是,catch中国一定要定义具体处理方式。
不要简单定义一句e.printStackTrace(),也不要简单的就写一条输出语句。

class Demo
{
int div(int a,int b)throws

ArithmeticException,ArrayIndexOutOfBoundsException
{
  int[] arr=new int[a];
  System.out.println(arr[4]);
  return a/b;
}
}
class ExceptionDemo
{
public static void main(String[] args)throws Exception
{
  Demo d=new Demo();
  try{
  int x=d.div(5,0);
  System.out.println("x="+x);
  }
  catch(ArithmeticException e)
  {
   System.out.println(e.toString());
   System.out.println("除零了!");
  }
  catch(ArrayIndexOutOfBoundsException e)
  {
   System.out.println(e.toString());
   System.out.println("角标越界!");
  }
  //不能与前面的catch交换位置,开发中一般不写这个catch。
  catch(Exception e)
  {
   System.out.println("出错了!");
  }
  System.out.println("over");
}
}

-----------------------
自定义异常

因为项目中会出现特有的问题,而这些问题并未被java所描述并封装对象。
所以对于这些特有的问题可以按照java的对问题封装的思想。将特有的问题,进行

自定义的异常封装。

需求:在本程序中,对于除数是-1,也视为是错误的是无法进行运算的。那么就需

要对这个问题进行自定义的描述。

当在函数内部出现了throw抛出异常对象,那么就必须;要给对应的处理动作。
要么在内部try catch处理
要么在函数上声明让调用者处理。
一般情况下,函数内出现异常,函数上需要声明。

如何定义异常信息?
因为父类中已经把异常信息的操作都完成了。
所以子类只要在构造时,将异常信息传给父类通过super语句。
就可以和直接通过getMessage方法获取自定义的异常信息。

自定义异常:
必须是自定义类继承Exception。

继承Exception原因:
异常体系有一个特点:因为异常类和异常对象都被抛出。
他们都具备可抛性。这个可抛性是Throwable这个体系中独有特点。
只有这个体系中的类和对象才可以被throws和throw操作。

throws和throw的区别
throws使用在函数上。
throw使用在函数内。

throws后面跟的异常类。可以跟多个,用逗号隔开。
throw后跟的是异常对象。

class FuShuException extends Exception
{
/*
private String msg;
FuShuException(String msg)
{
  this.msg=msg;
}
public String getMessage()
{
  return msg;
}
*/

private int value;
FuShuException(String msg,int value)
{
  super(msg);
  this.value=value;
}
public int getValue()
{
  return value;
}
}


class Demo
{
int div(int a,int b)throws FuShuException
{
  if(b<0)
   throw new FuShuException("出现了除数是负数的情况

/by FuShu",b);//手动通过throw关键字抛出一个自定义异常对象。
  return a/b;
}
}
class ExceptionDemo
{
public static void main(String[] args)
{
  Demo d=new Demo();
  try{
   int x=d.div(4,-2);
   System.out.println("x="+x);
  }
  catch(FuShuException e)
  {
   System.out.println(e.toString());
   System.out.println("出现异常的负数

是:"+e.getValue());
  }
  System.out.println("over");
 
}
}

-----------------------------------
RuntimeException

Exception中有一个特殊的子类异常RuntimeException运行时异常。
如果在函数内容抛出该异常,函数上可以不用声明,编译一样通过。
如果在函数上声明了该异常,调用者可以不用进行处理,编译一样通过。

之所以不用在函数上声明,是因为不需要让调用者处理。
当该异常发生,希望程序停止。因为在运行时,出现了无法继续运算的情况,希望

停止程序后,程序员对代码进行修正。

自定义异常时:如果该异常的发生,无法再继续运算,
就让自定义异常继承RuntimeException。

对于异常分两种
1,编译时被检测的异常。
2,编译时不被检测的异常(运行时异常,RuntimeException以及其子类)

--------------------------
异常练习

/*
毕老师用电脑上课。
*/

class LanPinException extends Exception
{
LanPinException(String message)
{
  super(message);
}
}
class MaoYanException extends Exception
{
MaoYanException(String message)
{
  super(message);
}
}

class NoPlanException extends Exception
{
NoPlanException(String message)
{
  super(message);
}
}

class Computer
{
private int state=3;
public void run() throws LanPinException,MaoYanException
{
  if(state==2)
   throw new LanPinException("蓝屏了");
  if(state==3)
   throw new MaoYanException("冒烟了");

  System.out.println("电脑运行");
}
public void reSet()
{
  System.out.println("电脑重启");
}
}
class Teacher
{
private String name;
Computer comp;
Teacher(String name)
{
  comp=new Computer();
  this.name=name;
}
public void jaoKe()throws NoPlanException
{
  try
  {
   comp.run();
  }
  catch(LanPinException e)
  {
   comp.reSet();
  }
  catch(MaoYanException e)
  {
   test();
   throw new NoPlanException("课时无法继

续"+e.getMessage());
  }
  System.out.println("教课");
}
public void test()
{
  System.out.println("练习");
}

}

class ExceptionTest
{
public static void main(String[] args)
{
  Teacher t=new Teacher("ZhangTeacher");
  try
  {
   t.jaoKe();
  }
  catch(NoPlanException e)
  {
   System.out.println(e.toString());
   System.out.println("换老师或放假");
  }
}
}

异常-finally

finally里存放的是一定会被执行的代码。


class FuShuException extends Exception
{
FuShuException(String msg)
{
  super(msg);
}
}
class Demo
{
int div(int a,int b)throws FuShuException
{
  if(b<0)
   throw new FuShuException("除数为负数");
  return a/b;
}
}
class ExceptionDemo
{
public static void main(String[] args)
{
  Demo d=new Demo();
  try
  {
   int x=d.div(4,-1);
   System.out.println("x="+x);
  }

  catch(FuShuException e)
  {
   System.out.println(e.toString());
  return;
  }
  finally
  {
   System.out.println("finally");
  }
  System.out.println("over");

}

}
//不执行over,执行finally
----------------------
异常-处理语句其他格式

1,
try
{}
catch()
{}

2,
try
{}
catch()
{}
finally
{}

3,
try
{}
finally
{}


catch是用于处理异常。如果没有catch就代表异常没有被处理过,如果该异常是检测时异常,那么必须声明。

-----------------------------------
异常在子父类覆盖中的体现。

1,子类在覆盖父类时,如果父类的方法抛出异常,那么子类的覆盖方法,只能抛出父类的异常或该异常的子类。
2,如果父类方法抛出多个异常,那么子类在覆盖该方法时,只能抛出父类异常的子集。
3,如果父类或者接口的方法中没有异常抛出,那么子类在覆盖方法时,也不可以抛出异常。如果子类发生了异常。就必须要进行try处理,绝对不能抛。

class AException extends Exception
{}
class BException extends AException
{}
class CException extends Exception
{}
class Fu
{
viod show()throws AException
{

}
}

class Zi extends Fu
{
void show() throws AException
}
//Zi只能抛AException,或BException,不能抛CException。


--------------------------------
异常-练习
/*
有一个圆形和长方形。
都可以获取面积。对于面积如果出现非法的数值,视为是获取面积出现问题。问题通过异常来表示。
*/
class NoValueException extends RuntimeException
{
NoValueException(String message)
{
  super(message);
}
}

interface Shape
{
public void getArea();
}

class Rec implements Shape
{
private int len,wid;
Rec(int len,int wid)
{
  if(len<0||wid<0)
   throw new NoValueException("长方形出现非法值"); 
   this.len=len;
   this.wid=wid;
}
public void getArea()
{
  System.out.println(len*wid);
}
}
class Circle implements Shape
{
private int radius;
public static final double PI=3.14;
Circle(int radius)
{
  if(radius<0)
   throw new NoValueException("圆长方形出现非法值"); 
  this.radius=radius;
}
public void getArea()
{
  System.out.println(radius*radius*PI);
}
}

class ExceptionTest
{
public static void main(String[] args)
{
  Rec r=new Rec(4,2);
  r.getArea();
  Circle c=new Circle(-3);
  c.getArea();
}
}

-----------------------
异常-总结

异常:是对问题的描述。将问题进行对象的封装。

异常体系:
Throwable
|--Error
|--Exception
  |--RuntimeException
异常体系的特点:异常体系中的所有类以及建立的对象都可以具备可抛性。也就是说可以被throw和throws关键字所操作。只有异常体系具备这个特点。
 

 
throw和throws的用法:
throw定义在函数内,用于抛出异常对象。
throws定义在函数上,用于抛出异常类,可以抛出多个,用逗号隔开。
当函数内容有throw抛出异常对象,并未进行try处理。必须要在函数上声明,否则编译失败。
注意,RuntimeException除外。也就是说,函数内如果抛出的RuntimeException异常,函数上可以不用声明。


如果函数声明了异常,调用者需要进行处理。处理方法可以throws可以try。

异常有两种:
编译时被检测异常
  该异常在编译时,如果没有处理(没有抛也没有try),编译失败。
  该异常被标识,代表着可以被处理。
运行时异常(编译时不检测)
  在编译时,不需要处理,编译器不检查。
  该异常的发生,建议不处理,让程序停止。需要对代码进行修正。
 
异常处理语句:
try
{}
catch()
{}
finally
{}

注意:
1,finally中定义的通常是关闭资源代码。因为资源必须释放。
2,finally只有一种情况不会执行。当执行到System.exit(0);系统推出 jvm结束。finally不会执行。
自定义异常:定义类继承Exception或者RuntimeException
1,为了让该自定义具备可抛性。
2,让该类具备操作异常的共性方法。

当要定义自定义异常的信息时,可以使用父类已经定义好的功能。将异常信息传递给父类的构造函数。

class MyException extends Exception
{
  MyException(String manage)
  {
   super(message);
  }
}
自定义异常:按照java的面向对象思想,将程序中出现的问题进行封装。

异常的好处:
1,将问题进行封装
2,将正常流程代码和问题代码想分离,方便与阅读。
异常的处理原则:
1,处理方式有两种:try或者throws。
2,调用到抛出异常的功能时,抛出几个,就处理几个。
  一个try对应多个catch。
3,多个catch,父类的catch放到最下面。
4,catch内,需要定义针对性的处理方式。不要简单那的定义printStackTrace,输出语句。也不要不写。当捕获到的异常本功能处理不了时,可以继续在catch中抛出。
try
{
  throw new AException();
}
catch(AException e)
{
  throw e;
}
如果该异常处理不了,但并不属于该功能出现的异常。可以将异常转换后,再抛出和该功能相关的异常。
或者异常可以处理,当需要将异常产生的和本功能相关的问题提供出去,让调用者知道,并处理。也可以将捕获异常处理后,转换新的异常。
try
{
  throw new AException();
}
catch(AException e)
{
  //对AException处理。
  throw new BException();
}

异常的注意事项:
在子父类覆盖时
1,子类抛出的异常必须是父类异常的子类或者子集。
2,如果父类或者接口没有异常抛出时,子类覆盖出现异常只能try不能抛。

------- android培训java培训、期待与您交流! ----------
标题SpringBoot智能在线预约挂号系统研究AI更换标题第1章引言介绍智能在线预约挂号系统的研究背景、意义、国内外研究现状及论文创新点。1.1研究背景与意义阐述智能在线预约挂号系统对提升医疗服务效率的重要性。1.2国内外研究现状分析国内外智能在线预约挂号系统的研究与应用情况。1.3研究方法及创新点概述本文采用的技术路线、研究方法及主要创新点。第2章相关理论总结智能在线预约挂号系统相关理论,包括系统架构、开发技术等。2.1系统架构设计理论介绍系统架构设计的基本原则和常用方法。2.2SpringBoot开发框架理论阐述SpringBoot框架的特点、优势及其在系统开发中的应用。2.3数据库设计与管理理论介绍数据库设计原则、数据模型及数据库管理系统。2.4网络安全与数据保护理论讨论网络安全威胁、数据保护技术及其在系统中的应用。第3章SpringBoot智能在线预约挂号系统设计详细介绍系统的设计方案,包括功能模块划分、数据库设计等。3.1系统功能模块设计划分系统功能模块,如用户管理、挂号管理、医生排班等。3.2数据库设计与实现设计数据库表结构,确定字段类型、主键及外键关系。3.3用户界面设计设计用户友好的界面,提升用户体验。3.4系统安全设计阐述系统安全策略,包括用户认证、数据加密等。第4章系统实现与测试介绍系统的实现过程,包括编码、测试及优化等。4.1系统编码实现采用SpringBoot框架进行系统编码实现。4.2系统测试方法介绍系统测试的方法、步骤及测试用例设计。4.3系统性能测试与分析对系统进行性能测试,分析测试结果并提出优化建议。4.4系统优化与改进根据测试结果对系统进行优化和改进,提升系统性能。第5章研究结果呈现系统实现后的效果,包括功能实现、性能提升等。5.1系统功能实现效果展示系统各功能模块的实现效果,如挂号成功界面等。5.2系统性能提升效果对比优化前后的系统性能
在金融行业中,对信用风险的判断是核心环节之一,其结果对机构的信贷政策和风险控制策略有直接影响。本文将围绕如何借助机器学习方法,尤其是Sklearn工具包,建立用于判断信用状况的预测系统。文中将涵盖逻辑回归、支持向量机等常见方法,并通过实际操作流程进行说明。 一、机器学习基本概念 机器学习属于人工智能的子领域,其基本理念是通过数据自动学习规律,而非依赖人工设定规则。在信贷分析中,该技术可用于挖掘历史数据中的潜在规律,进而对未来的信用表现进行预测。 二、Sklearn工具包概述 Sklearn(Scikit-learn)是Python语言中广泛使用的机器学习模块,提供多种数据处理和建模功能。它简化了数据清洗、特征提取、模型构建、验证与优化等流程,是数据科学项目中的常用工具。 三、逻辑回归模型 逻辑回归是一种常用于分类任务的线性模型,特别适用于二类问题。在信用评估中,该模型可用于判断借款人是否可能违约。其通过逻辑函数将输出映射为0到1之间的概率值,从而表示违约的可能性。 四、支持向量机模型 支持向量机是一种用于监督学习的算法,适用于数据维度高、样本量小的情况。在信用分析中,该方法能够通过寻找最佳分割面,区分违约与非违约客户。通过选用不同核函数,可应对复杂的非线性关系,提升预测精度。 五、数据预处理步骤 在建模前,需对原始数据进行清理与转换,包括处理缺失值、识别异常点、标准化数值、筛选有效特征等。对于信用评分,常见的输入变量包括收入水平、负债比例、信用历史记录、职业稳定性等。预处理有助于减少噪声干扰,增强模型的适应性。 六、模型构建与验证 借助Sklearn,可以将数据集划分为训练集和测试集,并通过交叉验证调整参数以提升模型性能。常用评估指标包括准确率、召回率、F1值以及AUC-ROC曲线。在处理不平衡数据时,更应关注模型的召回率与特异性。 七、集成学习方法 为提升模型预测能力,可采用集成策略,如结合多个模型的预测结果。这有助于降低单一模型的偏差与方差,增强整体预测的稳定性与准确性。 综上,基于机器学习的信用评估系统可通过Sklearn中的多种算法,结合合理的数据处理与模型优化,实现对借款人信用状况的精准判断。在实际应用中,需持续调整模型以适应市场变化,保障预测结果的长期有效性。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值