第15章

publi9色rtyolkne9yolk;๙}

publi9๗色rtyolkne9yolk;๙}

计来决定是否使用finaທl,而不是出于试图提高性能。

计来决定是否使用final,而不是出于试图提高性能。

publi9stringargs{

pubຘli9stringargs{

错误都源于程序员忘记初ม始化变量。特别是在使用程序库时,如果用户不知道如何初始化库

错误都源于程序员忘记初始化变量。特别是在使用程序库时,如果用户不知道如何初始化库

定所用的jdk版本。

定所用的jdk版本。

有图示。为了说明多态,我们要编写一段代码,它忽略类型的具体细节,仅仅和基类交互。

有图示。为ฦ了说明多态,我们要编写一段代码,它忽略类型的具体细节,仅仅和基类交互。

会了用java的思想去考虑问题、解决问题。本书๰不仅适合java的初学者,对于有经验的

会了用java的思想去考虑问题๤、解决问题。本书不仅适合java的初学者,对于有经验的

里用打印栈轨迹staທcktrace的方法来“修补”这个问题本章中的很多例子还是使

用了这个ฐ方法,看起来还是比较合适的。虽然这样可以跟踪异常的行为,但是你仍旧

不知道该如何处理异常。这一节,我们来研究一下“被检查的异常”及其并症,以及

采用什么方法来解决这些问题。

这个话题看起来简单,但实际上它不仅复杂,更重要的是还非常多变。总有人会顽ื固地

坚持自己的立场,声称正确也是他们的答案是显而易见的。我觉得之所以会有这种

观点,是因为ฦ我们使用的工具已๐经不是“ansi标准出台前的c那ว样的”弱类型语言

poorly-typed浪uage,而是像c++和javaທ这样的“强静态类型语言”strong

stati9guage,也๣就是编译时就做类型检查的语言,这是前๩者无法比拟

的。当你刚ธ开始这个转变的时候就像我一样,会现它带来的好处是那样的明显,

好像强类型检查总能解决所有的问题๤。在此,我想结合我自己的认识过程,告诉你我是

怎样从对类型检查的绝对迷信变成怀疑的;当然,很多时候它还是非常有用的,但是当

它挡住我们的去路并成为ฦ障碍的时候,我们就得跨过去。只是这条界限往往并不是很清

晰。我最喜欢的一句格言是:“所有模型都是错误的。但有些是能用的。”

历史

异常处理起源于pl1和mesa之类的系统中,后来又出现在clu,smalltalk,

摸dulaທ-3,ada,eiffel,9,jaທva以及jaທva后面的rubຘy和c#ี中。java

的设计和c++很相似,只是java的设计者去掉了一些他们认为c++设计得不好的东西。

为了能向程序员一个他们更愿意使用的错误处理和恢复的框架,异常处理机制很晚

才被加入c++标准化过程中,这个ฐ倡议是由9est肉strup所起的。

c++的异常模型主ว要借鉴了clu的作法。然而,当时其他语言已๐经支持异常处理了:包

括ada,smaທlltaທlk两者都有异常处理,但是都没有异常说明,以及摸dula-3๑它

既有异常处理也有异常说明。

liov和snyder在他们有关异常的开创น性论文

5

中指出,用9t

fashion报告错误的语言有一个主要缺陷,就是:

“…每次调用的时候都必须执行条件测试,以确定会产生何种结果。这使程序难以阅读,

并且有可能降低运行效率,因此程序员们既不愿意指出,也๣不愿意处理意外情况。”

5

barbaraliov和alaທnsnyder:9dlingin9๗sonsoft9๗aທre

engineering,vol色-5,no6,ไ1979年1้1้月。这篇论文在网上是找不到的,只有印刷版本,所以你得去图

书馆找一个副本。

注意,异常处理的初衷是要消除这种限制,但是我们又从java的“被检查的异常”上

看到了这种代码。他们继续写道:

“…在调用会引异常的函数的同时,还要求程序员给出异常处理程序,这会降低程序

的可读性,使得程序的正常思路被异常处理给破坏了。”

cນ++ใ异常的设计参考了clu方แ式。st肉strup声称其目标是减少恢复错误所需的代码。

我想他这话是说给那些“通常情况下都不写c的错误处理”的程序员们听的,因为ฦ要把

那么เ多代码放到那ว么多地方实在不是什么好差ๆ事。所以他们写c程序的习๤惯是,忽略所

有的错误,然后使用调试器来跟踪错误。这些程序员知道,使用异常就意味着他们要写

一些通常不用写的“多出来的”代码。因此,要把他们拉到“使用错误处理”的正轨上,

“多出来的”代码决不能太多。我认为,评价java的“被检查的异常”的时候,这一点

是很重要的。

c++还从clu那里还带来另一种思想:异常说明。这样就可以用编程的方式在方法签名