63 votes

Comment fait-on abattu un std::shared_ptr?

Considérer:

struct SomethingThatsABase
{
    virtual bool IsChildOne() const { return false; }
    virtual bool IsChildTwo() const { return false; }
};

struct ChildOne : public SomethingThatsABase
{
    virtual bool IsChildOne() const { return true; }
};

struct ChildTwo : public SomethingThatsABase
{
    virtual bool IsChildTwo() const { return true; }
};

void SomeClientExpectingAChildOne(std::shared_ptr<ChildOne> const& ptrOne)
{
    //Does stuff
}

void SomeClient(std::shared_ptr<SomethingThatsABase> const& ptr)
{
    if (ptr->IsChildOne())
    {
        SomeClientExpectingAChildOne(ptr); //Oops.
        //Hmm.. can't static_cast here, because we need a `shared_ptr` out of it.
    }
}

(Note que je ne peux pas tout simplement faire un std::shared_ptr<ChildOne>(static_cast<ChildOne*>(ptr.get())), parce que le nombre de références ne sont pas partagés entre les deux shared_ptrs)

91voto

mwigdahl Points 8768

Cela devrait fonctionner:

if (ptr->IsChildOne())
{
    SomeClientExpectingAChildOne(std::static_pointer_cast<ChildOne>(ptr));
}

34voto

Joel Points 312

L' shared_ptr équivalent d' static_cast est static_pointer_cast, et l' shared_ptr équivalent d' dynamic_cast est dynamic_pointer_cast.

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X