如果在一个析构函数中在销毁别几个同一对象时,这个对象在销毁时这个对象析构都抛出异常,这样同时作用的异常会导致不明确的行为
解决1 捕获异常并草率结束程序(不好)
2 捕获异常并记录(吞下异常) (不好)
3 在类中提供一个普通函数(非析构函数)给客户一个机会处理
class DBconn{
public:
...
void close(){//客户使用的新函数 失败抛出异常,且必须要处理
db.close();
closed = true;//如果必须
}
~DBConn(){//析构这时只负责处理异常 不会再面临上面两个尴尬
if(!closed){//非正常关闭
try{
db.close();
}
catch(...){
制作运转记录,记下对close的调用失败
}
}
}
private:
DBConnection db;
bool closed;
}
解决1 捕获异常并草率结束程序(不好)
2 捕获异常并记录(吞下异常) (不好)
3 在类中提供一个普通函数(非析构函数)给客户一个机会处理
class DBconn{
public:
...
void close(){//客户使用的新函数 失败抛出异常,且必须要处理
db.close();
closed = true;//如果必须
}
~DBConn(){//析构这时只负责处理异常 不会再面临上面两个尴尬
if(!closed){//非正常关闭
try{
db.close();
}
catch(...){
制作运转记录,记下对close的调用失败
}
}
}
private:
DBConnection db;
bool closed;
}