我班级中的构造函数检查某些条件。在某些情况下,它应该打破对象的创建。我应该在那里放一个析构函数还是只返回语句?
它是这样的:
代码中的某处:
new Obj( string );
和我的构造函数:
Obj::Obj( string ) {
if( string == "something" ) {
// should I put this here or only return?
Obj::~Obj();
return;
}
// ...
}
我知道我可以在创建对象之前检查条件,但我只是想知道它是否正确(如果没有内存泄漏),因为它编译得很好而不会在运行时崩溃。
答案 0 :(得分:10)
也不应该抛出异常。
不会创建任何对象,这是处理此类情况的惯用方法。
您需要在调用上下文(或更高版本)中处理异常。
Obj::Obj( string ) {
if( string == "something" ) {
// should I put this here or only return?
throw ObjectCouldNotBeCreatedException();
}
}
答案 1 :(得分:4)
return
语句仍会创建该对象。为了中断构造,你应该抛出异常。