c++智能指针有没有内存泄露的情况
上述代码中,parent有一个shared_ptr类型的成员指向孩子,而child也有一个shared_ptr类型的成员指向父亲。然后在创建孩子和父亲对象时也使用了智能指针c和p,随后将c和p分别又赋值给child的智能指针成员parent和parent的智能指针成员child。,weak_ptr的构造函数不会修改引用计数的值,从而不会对对象的内存进行管理,其类似一个普通指针,但是不会指向引用计数
·
答案是:有!
1.智能指针发生内存泄露的情况
当两个对象同时使用一个shared_ptr成员变量指向对方,会造成循环引用,使引用计数失效,从而导致内存泄露。
2.智能指针的内存泄漏如何解决?
为了解决循环引用导致的内存泄漏,引入了弱指针weak_ptr,weak_ptr的构造函数不会修改引用计数的值,从而不会对对象的内存进行管理,其类似一个普通指针,但是不会指向引用计数的共享内存,但是可以检测到所管理的对象是否已经被释放,从而避免非法访问。
eg:
#include<memory>
#include<iostream>
using namespace std;
class Child;
class Parent {
private:
shared_ptr<Child>ChildPtr;
public:
void setChild(shared_ptr<Child>child) {
this->ChildPtr=child;
}
void doSomething() {
if(this->ChildPtr.use_count()) {
}
}
~Parent() {
}
};
class Child{
private:
shared_ptr<Parent>ParentPtr;
public:
void setPartent(shared_ptr<Parent>parent) {
this->ParentPtr=parent;
}
void doSomething() {
if(this->ParentPtr.use_count()) {
}
}
~Child() {
}
};
int main() {
weak_ptr<Parent>wpp;
weak_ptr<Child>wpc;
{
shared_ptr<Parent>p(new Parent);
shared_ptr<Child>c(new Child);
p->setChild(c);
c->setPartent(p);
wpp=p;
wpc=c;
cout<<p.use_count()<<endl;
cout<<c.use_count()<<endl;
}
cout<<wpp.use_count()<<endl;
cout<<wpc.use_count()<<endl;
return 0;
}
程序运行结果:
2
2
1
1
上述代码中,parent有一个shared_ptr类型的成员指向孩子,而child也有一个shared_ptr类型的成员指向父亲。然后在创建孩子和父亲对象时也使用了智能指针c和p,随后将c和p分别又赋值给child的智能指针成员parent和parent的智能指针成员child。从而形成了一个循环引用。
更多推荐
已为社区贡献6条内容
所有评论(0)