c++ 析构函数 delete

#include <iostream>

using namespace std;

class BASE
{
public:
    virtual ~BASE()
    {
        cout<<"Base deconstruction"<<endl;
    }

};
class CCHILD: public BASE
{
public:
    ~CCHILD()
    {
        cout<<"CCHILD deconstruction"<<endl;
    }

};

int main(int argc, char const *argv[])
{
    BASE *Pbase;
    BASE b;
    Pbase = &b;
    delete Pbase;
    cout<<"-----"<<endl;
    CCHILD c;
    Pbase = &c;
    delete Pbase;
    return 0;
}

请大神解释,delete为什么提示无效的指针啊

阅读 6.2k
3 个回答

可以简单地认为C++的变量有两类,一类是在程序初始化时已经分配了固定空间的,另一类是由malloc动态申请的位于堆空间中的;
比如BASE b,那么变量b所在位置、所占空间等都是可以确定下来的,属于已经静态分配完成的变量,由编译器安排了其内存地址,是被写死在可执行文件中的;
而由malloc()/new申请的变量则是动态的,其地址在运行时才被告知,也只有这样的动态分配空间的变量才能被free()/delete释放空间
你的代码想要删除一个被写死在程序中的变量,怎么可能运行成功

老兄,我在你另一个问题里不是回答了么,关于 free()
http://segmentfault.com/q/1010000002985157

new/deletemalloc/free 是一回事。

哦,我错了,你那个问题问的也是 delete


如果你想使用 delete,一定记得跟 new 配对。

cppint main(int argc, char const *argv[])
{
    BASE *b = new BASE();
    delete b;
    cout<<"-----"<<endl;
    CCHILD *c = new CCHILD();
    delete c;
    return 0;
}

楼上的解释过于粗暴。。。 肿么也不能理解为写死在代码中吧 常量的位置是固定data段的

delete 分两部 调用析构函数 释放堆上内存,而你这种新建变量的方法是在栈上,是不能由你显示的delete的,你想想你删掉了栈上的一块 那么其他栈上资源要不要移动?那一移动offset就都不对了。。。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进