STL类指针容器container<class*> 元素clear 注意事项
来源:互联网 发布:手机淘宝兼职是真的吗 编辑:程序博客网 时间:2024/06/08 14:37
在使用 STL 容器时, 涉及到 C++多态(polymorphism)和虚函数时,经常会遇到使用容器存储类指针,当你要删除某个元素或者(erase)或者清空容器(clear)时,直接调用 erase或 clear 函数,指针指向的内存并不会释放,也就是说,对象不会被析构,这时就会导致内存泄漏(memory leak)。
示例代码:
#include <iostream>#include <list>using std::cout;class Base {public: virtual ~Base() {}};class Derived : public Base {};int main(int argc, char* argv[]){ using std::list; list<Base*> ls; ls.push_back(new Base()); ls.push_back(new Derived()); ls.push_back(new Base()); ls.clear(); return 0;}
编译后,使用内存检测工具 valgrind运行内存泄漏检测,得:
从图中可以发现程序中有三处内存泄漏,正对应着:
ls.push_back(new Base());ls.push_back(new Derived());ls.push_back(new Base());
可见,我们直接调用 clear()后指针对应的内存并没有被释放。而要消除内存泄漏,我们必须添加清理代码,对程序做以下修改:
#include <iostream>#include <list>using std::cout;class Base {public: virtual ~Base() {}};class Derived : public Base {};int main(int argc, char* argv[]){ using std::list; list<Base*> ls; ls.push_back(new Base()); ls.push_back(new Derived()); ls.push_back(new Base()); //添加清理代码 for(list<Base*>::iterator it=ls.begin(); it != ls.end(); ++it) delete *it; ls.clear(); return 0;}
再次运行 valgrind, 我们可以发现原来的内存泄漏消失。
有关 valgrind 的使用网上有很多,也可以查看本地帮助, 具体命令
valgrind --help
这里只是简单地开启 –leak-check 选项,另外程序在编译时加入“-g”选项,否则看不到发生内存泄漏的代码位置。
0 0
- STL类指针容器container<class*> 元素clear 注意事项
- STL 顺序容器注意事项
- stl容器内指针元素的使用与释放
- STL序列式指针容器中删除元素的方法
- auto_ptr智能指针不能作为STL标准容器的元素
- c++ STL 常用容器元素类型相关限制 指针 引用
- Stl 删除元素注意事项
- Stl 删除元素注意事项
- Clear Linux/Clear container
- CSS中clear清除元素容器浮动
- CSS中clear清除元素容器浮动
- STL组件(components)之容器(container)
- STL中容器适配器(Container Adapters)
- STL容器元素的删除
- stl容器遍历删除元素
- STL容器之 元素删除
- 安全删除STL容器元素
- STL容器内元素条件
- Android逆向中常用的ARM汇编指令基础知识
- Ubuntu下VIM的安装及其配置——Linux篇
- mybatis教程--查询缓存(一级缓存二级缓存和整合ehcache)
- arm中的uart
- Java内存模型
- STL类指针容器container<class*> 元素clear 注意事项
- Python IO流(Input&Output)
- Bootstrap进度条与AJAX后端数据传递结合使用
- 反向代理【nginx】
- Linux中文件查看命令cat/more/less
- 剑指offer-5.用两个栈实现队列
- Java图形界面Swing之窗体居中设置
- 团体程序设计天梯赛-练习集 -- L3-016. 二叉搜索树的结构(模拟)
- spring hibernate事务的流程