C++函数后面后加到关键字throw(something)限制,是对这个函数的异常安全性作出限制。
void f() throw() 表示f不允许抛出任何异常,即f是异常安全的。
void f() throw(...) 表示f可以抛出任何形式的异常。
void f() throw(exceptionType); 表示f只能抛出exceptionType类型的异常。
引别人的一个笑话:
throw() 大概会说:“噢,不管你抛什么,就是不准抛。。”
throw(...) 呵呵一笑,满脸慈祥:“抛吧抛吧,尽情地抛吧。。。”
throw(type) 一听急了:“那可不行,要抛也只能抛我的香烟头,否则要是不小心把俺祖传的金戒指抛掉就太亏了。。。”
关于C++的异常传递有三种方法:
1.传值(by value)
传值的过程中会产生临时对象的拷贝,不能解决多态的问题,如下:myexception继承exception,但是但确无法被正确的调用myexception的方法,造成对异常对象的切割。
Code
运行结果:UnKnown exceptions
程序执行是会调用exception的what方法,而不是myexception的what方法。
2.传指针(by pointer)
指针可以实现多态,但往往会将临时对象的地址作为指针传出去,出现悬挂指针错误。如果在堆上分配内存空间,又往往不知道何时删除对象,出现to be or not to be的错误。
结果显示:myException
Code
3.传引用(by reference)
传引用是最好的方法,可以克服前面的两个问题。
程序结果显示: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();
}
}
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();
}
}
小人本潜水在思源的贴边 ID又多 又有钱 快活乐无边 谁知道站总监 他蛮横不留情面 他勾结站长目无天 占我ID夺我钱 我马甲跟他来翻脸 反被他来把经验减 我同学骂他欺新人 反被他捉进了小黑屋里面 874了一百遍啊一百遍 啊 最后他咬舌自尽 遗恨人间 他还将我和马甲赶出了思源 流落在人间 我为求回思源 无奈行乞在贴前 谁知道站总监他实在太阴险 知道此情形竟派人来暗算将我发文狂删到0篇 小人ID强 残命独留全 可怜马甲他 竟遭删 为求养ID 惟有傍人卖身自作践 一面苦赚钱 一面写诗篇 发誓把名气显 手刃总监意志坚啊 从此总监ID念心间 我永铭记此仇不供戴天 |