不论尝试阻止的时候,异常事件会不会发生,或不管能不能得到处理,阻止总会执行。由于它总是被执行,所以我们推荐你在这里做一些清理。因此,正如所预料的那样,执行起来就是具有选择性的。
Try-catch模块的结构类似于switch-case的结构。在检查过的需要处理的异常事件中,是有可能在相同方法中将其处理或者抛出的。后者可以通过关键词抛出。在这种情况下,异常事件的种类必须在方法签名中被指定。看这个例子:
Void myMethod () throws SomeKindOfException{ // method goes here } |
接下来,我们将为大家展示更多的异常处理实例。
初学者常常与非匹配数据类型纠缠不清。通常,它们会引发一些问题,例如,在做加法时出现非数字型代码。下面给大家展示的代码中,出现了异常处理的工作环境。检查该网页以完成嵌入式Exception种类的清单。现在,我们要处理NumberFormatException 的发生。
public static void main (String args[] ) { double sum= 0; for (int i=0; i﹤args. length; ++1) try { sum+= Double.parseDboule (args[i]); } Catch (NumberFormatException e) { Ststem.out.printIn(args[i] + “non-numeric data on”); } System.out.printIn(“Total sum: “+ sum); } |
正如你所见到的,它和命令行参数一起运行,而且一旦轮到非数字型参数,它就会写入system.out,意指出现的问题。但是项目会继续进行,因为try模块是循环的。否则,没有合适的异常处理,项目就会终止。用这种方式总和还是可以计算处理并在最后显示处理。
我们来看看另一个例子。在这个例子中,我们会要建立自己的异常实例类,该类扩展了其母Exception类。应用程序会模拟用于异常处理和抛出的堆栈机制,如堆栈是满的或者是空的。检查一下。
Public class StackException extends Exception { Public StackException (String text) { Super (text) } } |
现在让我们创建一个Stack类。注意push和pop方法。它们正抛出StackException,而这一动作由方法签名导入。此外,还有一个if条件,且条件满足时,异常事件会被抛出。否则,一切都会顺利运行。
public class Stack { private final int SIZE = 100; private Object st[]; private int size; private int sp; public Stack (int size) { if (size < MAXSIZE) this.size = size; else this.size = MAXSIZE; this.st = new Object [size]; this.sp = -1; } public void push (Object o) throws StackException { if (sp == this.size - 1) throw new StackException ("Stack is full"); this.st [++this.sp] = o; } public Object pop () throws StackException { if (sp == -1) throw new StackException ("Stack is empty"); Object o = this.st [this.sp]; this.sp--; return o; } public boolean isEmpty() { return this.sp == -1; } } |
好的,现在是时候写一写Main class连同主要方法了。在这一部分,请对try-catch语句给予更多关注。有两类异常情况可以被捕捉到。你也可以很容易地找出它们。