C++ 内存泄露
2016-05-02 17:36
447 查看
C++内存泄露主要发生在浅拷贝阶段:
例如#include<iostream>
#include<string>
#include<cstring>
#include<memory>
using namespace std;
class A
{
private:
char *m;
size_t n;
public:
A(size_t n=1)
{
cout<<"i want to creat it"<<endl;
m=new char
;
this->n=n;
}
~A()
{
cout<<"i ready to destory it"<<endl;
delete m;
}
char *getbuf()
{
return m;
}
};
void foo()
{
auto_ptr<A>p(new A);
auto_ptr<A>b=p;
auto_ptr<A>c(new A);
c=p;
}
int main()
{
A a(1);
A b=a;
//b=a;
}
由于发生了浅拷贝,所以程序退出的时候,就中断了,因为同一内存析够了2次。至于为什么同一对象析够2次就会中断,是因为已经析够的对象所占据的内存已经还给操作系统,再次访问时,就报错了。
为此,c++创造了智能指针,但是智能指针都有缺陷。
1.auto_ptr:确定是在copy时候,会释放所有权,而且不可以用于数组。
2.scoped_ptr克服了auto_ptr在复制的时候,释放所有权的缺点。
3.scoped_array 是scoped_ptr的扩展形式,可以用于数组。
4.share_ptr可以拷贝,可复制的智能指针,但是不可以循环引用。
5,.wear_ptr指针检测share_ptr是否循环引用。
例如#include<iostream>
#include<string>
#include<cstring>
#include<memory>
using namespace std;
class A
{
private:
char *m;
size_t n;
public:
A(size_t n=1)
{
cout<<"i want to creat it"<<endl;
m=new char
;
this->n=n;
}
~A()
{
cout<<"i ready to destory it"<<endl;
delete m;
}
char *getbuf()
{
return m;
}
};
void foo()
{
auto_ptr<A>p(new A);
auto_ptr<A>b=p;
auto_ptr<A>c(new A);
c=p;
}
int main()
{
A a(1);
A b=a;
//b=a;
}
由于发生了浅拷贝,所以程序退出的时候,就中断了,因为同一内存析够了2次。至于为什么同一对象析够2次就会中断,是因为已经析够的对象所占据的内存已经还给操作系统,再次访问时,就报错了。
为此,c++创造了智能指针,但是智能指针都有缺陷。
1.auto_ptr:确定是在copy时候,会释放所有权,而且不可以用于数组。
2.scoped_ptr克服了auto_ptr在复制的时候,释放所有权的缺点。
3.scoped_array 是scoped_ptr的扩展形式,可以用于数组。
4.share_ptr可以拷贝,可复制的智能指针,但是不可以循环引用。
5,.wear_ptr指针检测share_ptr是否循环引用。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- C++联合体转换成C#结构的实现方法
- C++高级程序员成长之路
- C++编写简单的打靶游戏
- C++ 自定义控件的移植问题
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- 使用Lua来扩展C++程序的方法
- C++中调用Lua函数实例
- Lua和C++的通信流程代码实例
- C与C++之间相互调用实例方法讲解
- 解析C++中派生的概念以及派生类成员的访问属性