2012-05-10 12 views
7

Ich versuche, 'dies' an den Konstruktor übergeben std :: make_sharedC++ 11 Passing 'this' als Paramenter für std :: make_shared

Beispiel:

// headers 
class A 
{ 
public: 
    std::shared_ptr<B> createB(); 
} 


class B 
{ 
private: 
    std::shared_ptr<A> a; 

public: 
    B(std::shared_ptr<A>); 
} 


// source 
std::shared_ptr<B> A::createB() 
{ 
    auto b = std::make_shared<B>(this); // Compiler error (VS11 Beta) 
    auto b = std::make_shared<B>(std::shared_ptr<A>(this)); // No compiler error, but doenst work 
    return b; 
} 

Doch diese funktioniert nicht richtig, irgendwelche Vorschläge, wie ich das als Argument richtig weitergeben kann?

Antwort

13

Ich denke, was Sie wahrscheinlich hier wollen, ist shared_from_this.

// headers 
class A : std::enable_shared_from_this<A> 
{ 
public: 
    std::shared_ptr<B> createB(); 
} 


class B 
{ 
private: 
    std::shared_ptr<A> a; 

public: 
    B(std::shared_ptr<A>); 
} 


// source 
std::shared_ptr<B> A::createB() 
{ 
    return std::make_shared<B>(shared_from_this()); 
} 

aktualisieren comments from David Rodriguez enthalten:

Beachten Sie, dass shared_from_this() sollte nie auf einem Objekt aufgerufen werden, die nicht bereits von einem shared_ptr verwaltet wird. Dies gilt:

shared_ptr<A> a(new A); 
a->createB(); 

Während die folgende führt zu undefinierten Verhalten (Versuch delete auf a zu nennen):

A a; 
a.createB(); 
+0

Thanks a lot Andrew! – RdR

+7

Es ist wichtig zu beachten, dass 'shared_from_this()' erfordert, dass das aktuelle Objekt bereits in einem 'shared_ptr' verwaltet wird. I.e. 'int main() {A a; a.createB(); } 'ist undefiniertes Verhalten, während' int main() {shared_ptr a (neues A); a-> createB(); } 'ist richtig. –

+0

@ DavidRodríguez-dribeas Absolut. Ich habe die Antwort entsprechend aktualisiert. Vielen Dank. –

Verwandte Themen