C++ 内存溢出&内存泄漏

内存溢出(OutOfMemory)是指程序申请内存时,没有足够的内存供申请者使用。

内存溢出的原因:1.内存中加载的数据量过于庞大,如一次从数据库取出过多数据。

                             2.集合类中有对象的引用,使用完后为清空,使得不能回收。

                             3.代码中存在死循环或循环产生过多重复的对象实体。

内存泄漏(memory leak)是指由于疏忽或错误造成了程序未能释放掉不再使用的内存的情况。

 

两种类型的内存泄漏:(摘自网上)

(1)堆内存泄漏 (Heap leak)。对内存指的是程序运行中根据需要分配通过malloc,realloc new等从堆中分配的一块内存,再是完成后必须通过调用对应的 free或者delete 删掉。如果程序的设计的错误导致这部分内存没有被释放,那么此后这块内存将不会被使用,就会产生Heap Leak. 

(2)系统资源泄露(Resource Leak).主要指程序使用系统分配的资源比如 Bitmap,handle ,SOCKET等没有使用相应的函数释放掉,导致系统资源的浪费,严重可导致系统效能降低,系统运行不稳定。 
--------------------- 

 

遇到的内存泄漏的问题:

1. 通过基类指针删除派生类对象!--->only 调用了基类的析构函数。例如:

int main () {
    Base *b = new Derived(); //Derived 是 Base 的派生类。
    b->dosomething();
    delete b;
    return 0;
}

如果Base基类的析构函数~Base()没有声明为虚函数,则只能输出

Base destructor。

如果定义了虚函数,则可以会输出

Derived destructor.

Base destructor.

可以看出,派生类的析构函数被调用,使用了虚函数,实现了多态。

 

那么,为什么默认的析构函数不是虚函数呢?

     默认不是虚析构函数是因为如果析构函数为虚函数就需要编译器在类中增加虚函数表来实现虚函数机制,这样所需内存空间就更大了,因此没有必要默认为虚析构函数。同时,该类没有派生类,则就不需要设置为虚析构函数。

 

2. 堆内存未释放产生的内存泄漏问题

int *p = new int;
int t = 3;
p = &t;
delete p;//delete掉的是栈上的内存,而堆上的内存再也无法释放。

3. shared_ptr循环引用,造成内存泄漏

C++ 内存溢出&内存泄漏_第1张图片

你可能感兴趣的:(C++)