答案是:有!

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。从而形成了一个循环引用。

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐