我需要找到一个解决方案,以允许子类获得正确的智能指针。
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){ ... }
...
}
通常我只会使用这个指针,一切都会很好。我已经让通知程序使用了模板,所以我只能将消息传递给那些想要听到它们的人。
但是,我想使用智能指针。如果通知程序如下所示:
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());
...
}
这似乎适用于身体。然而,它并不适用于身体的子类(或者,至少,它似乎不起作用):
class BodyChild : public Body {
public:
BodyChild(){
Notifier<BodyMessage>::register(get_shared_ptr());
}
很可能是因为我不能投shared_pointer。所以,我能给你一个解决办法吗
我对其他想法持开放态度,但如果我能让它发挥作用,我会很兴奋的。
发布于 2012-03-19 11:48:26
您可以强制转换智能指针,Boost为您提供了一些模板来简化此操作。你已经成功了。static_pointer_cast
和dynamic_pointer_cast
,它们允许您“通过”指针进行转换。
由于this
是正确的动态类型,所以可以在shared_from_this()
的返回值上调用boost::static_pointer_cast
。
boost::shared_ptr<Child> p = static_pointer_cast<Child>(shared_from_this());
(由于Koenig查找,不需要对static_pointer_cast
进行限定)
https://stackoverflow.com/questions/9776802
复制相似问题