现在的位置: 首页 > 综合 > 正文

一种简单的不依赖于编程语言的异常处理方法

2013年01月11日 ⁄ 综合 ⁄ 共 703字 ⁄ 字号 评论关闭

现在有很多支持异常处理的编程语言。我现在想说的是在 C 语言等不支持异常处理的语言中怎样实现多路的异常处理功能。

首先,所有可能抛出异常的函数,都返回一个布尔型值。当返回值为真时,表示没有异常。否则表示有异常。此外用一个全局(或线程全局)变量记录异常信息。

第二,在函数内,返回值一开始置为真。异常一旦抛出(可以是从库函数如 fputs 等引发,也可以是从其他抛出异常的函数返回),就将返回值置为假,再跳转到回收资源处理位置(类似于 finally),最后返回。在异常发生时,加入异常信息及当前函数信息(最好是在 finally 处理的一开始判断是否有异常,如果有就加入本函数的信息)。

第三,对于特定意义要分离的异常类型(比如想把网络异常与内存异常分离,内存异常通过普通异常渠道通知,而网络异常要有一些不同),可以通过参数传入一个布尔型变量的地址,通过修改该布尔型变量的值来表示是否有特定类型的异常(如网络异常)。这样,当外面的函数捕获异常后,可以判断是否网络异常还是其他异常。

第四,如果异常捕获后要从中恢复,一般有两种方法:备份-恢复及日志-回滚。备份-恢复是指在最外层需要恢复异常的函数在调用可能发生异常的函数前备份所有将被影响到的数据,然后一旦发生异常就恢复所有数据。日志-回滚是指最外层函数创建一个日志,然后传给被调用的函数。每个修改数据的函数都往指定日志记录恢复信息。一旦发生异常就回滚整个日志中所记录的修改。显然备份-恢复方法比较简单,出错的可能性也较小,在能使用它的时候尽量使用它。

恢复的用处主要是重试。需要注意的是如果重试多次不成功,可能需要再向外继续抛出异常,而不是忽略掉,否则可能影响程序后续的处理过程。

抱歉!评论已关闭.