我有一个类,它有一个指向基类的std::vector
指针,它具有不同的派生类。如何在vector
课程中调用他们的析构函数?
holder.h
class holder
{
public:
void add_stuff();
void do_stuff();
private:
std::vector<base*> vect;
};
holder.cpp
void holder::add_stuff(base* to_add) {
vect.push_back(to_add);
}
void holder::do_stuff() {
vect[0]->say_words();
delete vect[0]; //<--<--<-- I want to delete the object now
}
如果你知道我做错了什么,请立即停止。我已经包含了其余代码的基本知识,以防我离开。
base.h
class base
{
public:
base();
virtual ~base();
virtual void say_words() = 0;
};
derived.h
class derived : public base
{
public:
derived();
~derived();
void say_words();
};
derived.cpp
derived::derived() {}
derived::~derived() {}
void derived::say_words() {
cout << "Words!" << endl;
}
的main.cpp
holder hold;
holder* H = &hold;
int main(){
base* d = new derived();
H->add_stuff(d);
H->do_stuff();
}
答案 0 :(得分:0)
如何在
vector
班级内调用他们的析构函数?
由于~base
析构函数被标记为virtual
,因此您已经存在。在指向基类的指针上调用delete
将自动为您调用所有派生的析构函数。那就是 WHY 基类析构函数首先需要声明为virtual
。
您缺少的是在std::vector
对象之后从delete
移除对象指针,例如:
void holder::do_stuff() {
vect[0]->say_words();
delete vect[0]; // <-- calls all destructors of this object!
vect.erase(vect.begin()); // <-- add this line!
}
您不想在容器中留下无效指针。