有可能单个catch不能完全处理一个异常。在进行了一些校正行动之后,catch可能确定该异常必须由函数调用链中更上层的函数来处理,catch可以通过重新抛出(rethrow)将异常传递给函数调用链中更上层的函数。重新抛出是后面不跟类型或表达式的一个throw:
throw;
空throw语句将重新抛出异常对象,它只能出现在catch或者从catch调用的函数中。如果在处理代码不活动时碰到空throw,就调用terminate函数。
虽然重新抛出不指定自己的异常,但仍然将一个异常对象沿链向上传递,被抛出的异常是原来的异常对象,而不是catch形参。当catch形参是基类类型的时候,我们不知道由重新抛出表达式抛出的实际类型,该类型取决于异常对象的动态类型,而不是catch形参的静态类型。例如,来自带基类类型形参catch的重新抛出,可能实际上抛出一个派生类型的对象。
一般而言,catch可以改变它的形参。在改变形参之后,如果catch重新抛出异常,那么,只有当异常说明符是引用的时候,才会传播那些改变。
catch(my_error& eObj) { //specifier is a reference type
eObj.status=serveErr; //modifies the exception object
throw; //the status members of the exception object is severeErr
} catch(other_error eObj) { //specifier is a nonreference type
eObj.status=badErr; //modifies local copy only
throw; //the status member of the exception rethrown is unchanged
}