简介

内存泄漏,一言以蔽之:程序运行时,分配在堆上的内存,程序结束后未释放。

触发场景

  1. malloc或realloc创建的对象未free(new创建的对象未delete)
  2. 第三方库中,构建对象和销毁对象的方法成对出现,遗漏调用销毁对象的方法
  3. 继承基类的析构函数非纯虚析构,当前类析构函数中处理内存释放
  4. 对象所有权转移过程中,未判定是否转移成功,或原指针对象的销毁
  5. delete一个指针数组时,未添加[]

规避措施

  1. C++代码中,避免直接使用C方法
  2. 当不得不使用C方法时,对C方法进行封装,实现封装内部内存自管理,减少C类代码的影响范围
  3. 永远不要暴露、传递或直接使用指针对象,引用优先,auto_ptr或shared_ptr次之
  4. 对象创建时应就近确定其生命管理器(例如:auto_ptr管理指针;使用Guard确保出作用域调用销毁函数)
  5. 对象的生命,当在出创建他的作用域时销毁,除非所有权转移给更高级别的对象管理者
  6. 类的析构函数统一定义为纯虚函数(此处舍弃最小权限原则)
  7. 类的构造函数与析构函数相邻,确保每个手动分配的内存,在析构函数中都有对应的释放
  8. 对象发生所有权转移,必须考虑两种场景:转移失败,当前对象是否可销毁;转移成功,目的容器中之前是否存在对象,其对象是否已销毁
  9. 对象管理器管理多级对象时,每一级对象都必须在上一级中有明确的生命管理
  10. 切勿使用指针数组,封装具有对象生命管理ObjectPtrVector类最优