自定义异常及RuntimeException-------------黑马程序员


 (1)因为项目中会出现特有的问题,
  而这些问题并未被java所描述并封装对象
  所以对于这些特有的问题可以按照java的对问题封装的思想。
  将特有的问题,进行自定义的异常封装
 (2) 当函数内部出现了throw抛出异常对象,那么就必须要给对应的处理动作。
  要么在内部try catch处理
  要么在函数上声明让调用者处理
  一般情况下,函数内出现异常,函数上需要声明
 (3) 发现打印的结果只有异常的名称,却没有异常的信息,因为自定义的异常并未定义信息
  因为父类中已经把异常信息的操作都完成了,所以子类只要在构造时候,将
  异常信息传递给父类通过super语句
  那么就可以直接通过getMessage方法获得异常信息。
 (4)自定义异常:
  必须是自定义类继承Exception
 (5)继承Exception原因:
 异常体系有一个特点:因为异常类和异常对象被抛出,他们都具备可抛型,
 这个可抛型是Throwable这个体系中的独有特点,
 (6)只有这个体系中的类和对象可以被throw和throw操作
  a.throws和throw的区别
  throw使用在函数上,
  throw使用在函数内。
 
  throw后面跟的异常类,可以跟多个,用逗号隔开
  throw 后面跟的是异常对象
 
 (7)Exception中有一个特殊 的子类异常RuntimeException运行时异常
  如果在函数内容抛出该异常,函数可以不用声明,编译一样通过
  如果在函数上声明了该异常,调用者可以不用进行处理,编译一样通过
 之所以不用在函数声明,是因为不需要让调用者处理,当该异常发送,希望程序停止,
  因为在运行时候,出现了无法继续运算的情况,希望停止程序后,对代码进行修正
 
 (8)自定义异常时候:如果该异常的发送,无法在继续进行运算,
  就让自定义异常继承RuntimeException
 
 (9)对于异常分两种:
  1.编译时被检测的异常
  2.编译时不被检测的异常(运行时候异常,RuntimeException以及其子类)

 


 在本程序中,对于除数是负数,也视作错误的,无法进行运算,那么就需要对这个问题进行自定义的描述

class FuShuException extends RuntimeException {// getMessage
	private int value;

	FuShuException() {
		super();
	}

	FuShuException(String msg, int value) {
		// TODO Auto-generated constructor stub
		super(msg);
		this.value = value;
	}

	public int getValue() {
		return value;
	}

}

class Demo {
	int div(int a, int b) {
		if (b < 0) {
			throw new FuShuException("出现了除数是负数的情况/by 负数", b);// 手动通过throw抛出异常
		}
		if (b == 0) {
			throw new ArithmeticException("被0除了");
		}
		return a / b;
	}
}

public class ExceptionByIden {
	public static void main(String[] args) {
		Demo demo = new Demo();
		int x;
		try {
			x = demo.div(4, -1);
			System.out.println("x = " + x);
		} catch (FuShuException e) {
			System.out.println(e.toString());
			System.out.println("除数出现负数");
			System.out.println("错误的负数是:" + e.getValue());
		} catch (Exception e) {
			System.out.println(e.toString());
		}

		System.out.println("over");
	}

}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值