本文共 1287 字,大约阅读时间需要 4 分钟。
delete=1.调用析构函数,释放对象中的成员资源
2.归还对象空间(free)
其中在调用析构函数的时候,有可能还会对其他对象进行delete,然后调用这个对象的析构函数。。。
看这个例子:
转载原文地址:
delete用于释放new在堆中动态生成的对象空间。
释放时会自动调用类的析构函数,在析构函数中用于释放类内部动态分配的得到的资源。然后delete再释放整个对象所占的内存空间
simple: #include <iostream> using std::cout; using std::endl; class Simple{ public: Simple(){ p = new int; //使用new分配空间 *p = 10; pArray = new int[*p]; //使用new分配数组空间 for(int i = 0; i < *p; i++) pArray[i] = i; }~Simple(){ cout << "\ndisconstuctor\n" << "now delete p" << endl; delete p; cout << "now delete pArray" << endl; delete [] pArray; //注意这里的释放配对 } public: void out(){ cout << "p value = " << *p << endl; for(int i = 0; i < *p; i++) { cout << "array is " << *(pArray + i) << endl; } } private: //disable copy & assign control Simple(const Simple&); const Simple& operator=(const Simple&); private: int *p; int *pArray; }; int main() { Simple* s = new Simple; //生成堆对象 s->out(); delete s; //释放对象//delete s的过程中首先调用析构函数~simple()释放成员资源,然后释放对象的空间
//在~simple()的过程中:因为simple()的过程中,有开辟新空间,所以这个必须delete,如果这个过程中没有new,那么这里也没必要delete,在这个delete的过程中,也调用了int这个类的析构函数,在int这个类里的析构函数中,首先释放成员资源,然后释放空间,当整个对象中的成员资源被释放之后,等于是该对象的析构函数执行完毕。然后delete释放整个对象的空间。
return 0; }而delete this如果发生在析构函数中,每次delete---->调用析构函数,析构函数又delete this导致了堆栈内存。。。
如果是发生在成员函数中,之后如果不用到成员资源(比如某个成员变量和虚函数)可以,如果用到,会报错,因为这块资源已经被释放掉,找不到数据了。