`
phinecos
  • 浏览: 343508 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

《Java编程思想》读书笔记(12)

 
阅读更多

以前学c语言时,总是在自己写的函数里为程序的各种运行情况设置一个返回标志值,返回值可以是10等标志值,来根据这些标志值来判断程序是否正常运行,但代码多了就总是搞不清楚这些标志值之间的区别,因此代码就变得很难读了。而java用“异常处理”很好地解决了这个恼火的问题。

异常处理理论上划分为两种:中止模型(temination),也就是javac++采用的模型,它假定错误十分严重,因此无法回到错误的地方,只能抛出异常。还有一种就是“继续(resumption),它认为异常处理程序应该能对当前的运行环境进行修复,然后尝试上次出错了的方法。也就是说处理完异常后,希望能够继续运行当前指令。但这种模型的”耦合性“太大。

packagecom.vitamin.Console;
importjava.lang.
*;

publicclassexceptionTest
{

/**//**
*@paramargs
*/

publicstaticvoidmain(String[]args)
{
//TODOAuto-generatedmethodstub
try
{
f();
}

catch(MyExceptionex)
{
System.err.println(ex.getMessage().toString());
}


}

publicstaticvoidf()throwsMyException
{
System.
out.println("Hello");

}


}

Java异常处理中存在着一个错误,如果用如下方式去使用的话就会出错:

packagecom.vitamin.Console;
importjava.lang.Throwable;


publicclassexceptionTest
{

publicstaticvoidmain(String[]args)throwsException
{
//TODOAuto-generatedmethodstub
try
{
g();
}

finally
{
f();
}

}

publicstaticvoidg()throwsException
{
thrownewException("异常1");
}

publicstaticvoidf()throwsMyException
{
thrownewMyException("异常2");

}


}

异常2把异常1给弄丢了!!!

在覆写一个方法时,只能抛出这个方法在基类中的版本所声明的异常,这样就可以实现多态性。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics