我们可以把整个函数包含在一个try块中,这种try块被称为函数try块。例如:
int main()
try{
//main()的函数体
}
catch(pushOnFull){
// ...
}
catch(popOnEmpty){
// ...
}
函数try块对于类的构造函数来说是必须的。当一个类的构造函数在初始化时出现抛出异常,我们该如何处理呢?这时我们可以使用try块。try块的位置如何放置呢?例如,下面这样放置能够起到作用吗?
inline Account::Account(const char* name,double opening_bal)
: _balance(opening_bal-serviceCharge())
{
try
{
_name = new char[strlen(name)+ 1] ;
strcpy(_name,name) ;
// ...
}
catch( ... ){
//特殊处理
//不能捕获来自成员初始化表的异常
}
}
因为try块不会包含成员初始化表,所以构造函数体尾部的catch子句不会考虑由“在成员初始化表中函数serviceCharge()”抛出的异常。这时,我们应该使用函数try块。注意成员初始化表的位置、如下所示:
inline Account::Account(const char* name,double opening_bal)
try
: _balance(opening_bal-serviceCharge()) //注意成员初始化表和try的位置
{
_name = new char[strlen(name)+ 1] ;
strcpy(_name,name) ;
// ...
}
catch( ... )
{
//特殊处理
//不能捕获来自成员初始化表的异常
}
我们可以注意到:关键字try被放在成员初始化表之前,try块的复合语句包围了构造函数体。现在,catch子句catch(...)被用来处理“从成员初始化表或构造函数体内抛出的所有异常”。
1303

被折叠的 条评论
为什么被折叠?



