轉(zhuǎn)自:http://www.cnblogs.com/CUCmehp/archive/2009/01/12/1374320.html
C++函數(shù)后面后加到關(guān)鍵字throw(something)限制,是對這個函數(shù)的異常安全性作出限制。
void f() throw() 表示f不允許拋出任何異常,即f是異常安全的。
void f() throw(...) 表示f可以拋出任何形式的異常。
void f() throw(exceptionType); 表示f只能拋出exceptionType類型的異常。
引別人的一個笑話:
throw() 大概會說:“噢,不管你拋什么,就是不準(zhǔn)拋。。”
throw(...) 呵呵一笑,滿臉慈祥:“拋吧拋吧,盡情地拋吧。。。”
throw(type) 一聽急了:“那可不行,要拋也只能拋我的香煙頭,否則要是不小心把俺祖?zhèn)鞯慕鸾渲笒伒艟吞澚?。?!?#8221;
關(guān)于C++的異常傳遞有三種方法:
1.傳值(by value)
傳值的過程中會產(chǎn)生臨時對象的拷貝,不能解決多態(tài)的問題,如下:myexception繼承exception,但是但確無法被正確的調(diào)用myexception的方法,造成對異常對象的切割。
class myexception:public exception{
public:
virtual const char* what() throw();
};
const char* myexception::what(){
return "myException";
}
class A{
public:
A(){}
void f() throw(){
throw myexception();
}
};
int main(){
A a;
try{
a.f();
}catch(exception exc){
cout<<exc.what();
}
}
運行結(jié)果:UnKnown exceptions
程序執(zhí)行是會調(diào)用exception的what方法,而不是myexception的what方法。
2.傳指針(by pointer)
指針可以實現(xiàn)多態(tài),但往往會將臨時對象的地址作為指針傳出去,出現(xiàn)懸掛指針錯誤。如果在堆上分配內(nèi)存空間,又往往不知道何時刪除對象,出現(xiàn)to be or not to be的錯誤。
結(jié)果顯示:myException
Code
class myexception:public exception{
public:
virtual const char * what() const;
};
const char* myexception::what() const{
return "myException";
}
class A{
public:
A(){}
void f() throw(){
throw new myexception();
}
};
int main(){
A a;
try{
a.f();
}catch(exception* pexc){
cout<<pexc->what();
delete pexc;
}
}
3.傳引用(by reference)
傳引用是最好的方法,可以克服前面的兩個問題。
程序結(jié)果顯示:myException
Code
class myexception:public exception{
public:
virtual const char * what() const;
};
const char* myexception::what() const{
return "myException";
}
class A{
public:
A(){}
void f() throw(){
throw myexception();
}
};
int main(){
A a;
try{
a.f();
}catch(exception& exc){
cout<<exc.what();
}
}