c – 子类和get_shared_from_this()

前端之家收集整理的这篇文章主要介绍了c – 子类和get_shared_from_this()前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我需要找到一个解决方案,允许子类获得正确的智能指针.
class Parent : public enable_shared_from_this {
  ...
}

class Child : public Parent {
  public Child(){
    boost::shared_ptr<Parent> pointer=shared_from_this(); // should work
    boost::shared_ptr<Child> pointer=shared_from_this(); // won't work.

  ...
}

如何使用shared_from_this()获得正确的智能指针?

背景:

我正在写一些通知器/监听器的东西,有些类自然需要从通知注册和取消注册.例如,

class Body : extends Listener<BodyMessage>{ // listen for BodyMessage messages
  public:
    Body() {
      Notifier<BodyMessage>::register(this); // register with the appropriate notifier
    }

    virtual ~Body {
      Notifier<BodyMessage>::unregister(this); // unregister
    }

    bool notify(BodyMessage m){ ... }

  ...
}

通常我会使用这个指针,一切都会好的.我已经让Notifier使用模板,因此我只能将消息传递给想要听到它们的消息.

但是,我想使用智能指针.如果通知程序如下所示:

template<typename t>
class Notifier {
  public:
    static void register<boost::shared_ptr<Listener<t>>> boost::shared_ptr<Listener<t>> listener);

  ...
}

然后我再也不能使用这个指针了.当然,我让Body扩展了enable_shared_from_this:

class Body : public boost::enable_shared_from_this,public Listener<BodyMessage> {
  public:
    Notifier<BodyMessage>::register(get_shared_ptr());
  ...
}

这似乎适用于Bodies.但是,对于实体的子类(或者,至少它似乎不是),它不起作用:

class BodyChild : public Body {
  public:
    BodyChild(){
      Notifier<BodyMessage>::register(get_shared_ptr());
}

可能是因为我无法施放shared_pointer.那么,我能解决这个问题吗?

>让我为侦听器使用共享指针(因为这些侦听器也用于其他智能指针上下文),
>让我模板通知程序和监听器,使用模板的消息类型本身,这样就可以非常容易地监听特定的消息,因此我不必解码消息,
>很简单?

我对其他想法持开放态度,但如果我能让它发挥作用,我会很激动.

解决方法

您可以投射智能指针,Boost为您提供了一些模板来简化这一点.你有例如. static_pointer_cast和dynamic_pointer_cast允许你“转换”指针.

由于这是正确的动态类型,您可以在shared_from_this()的返回值上调用boost :: static_pointer_cast:

boost::shared_ptr<Child> p = static_pointer_cast<Child>(shared_from_this());

(由于Koenig查找,无需限定static_pointer_cast)

猜你在找的C&C++相关文章