好的,我开始使用共享指针并尽可能地传递共享指针.不再转换为原始指针.除了在这种特殊情况下,这很好用:
假设我们有一个类也是另一个类的观察者,如下所示:
class MyClass : public IObserver { public: MyClass (std::shared_ptr<SomeOtherClass> otherClass); void DoSomethingImportant(); private: std::shared_ptr<SomeOtherClass> m_otherClass; };
这个类在我的应用程序中使用如下:
std::shared_ptr<MyClass> myInstance(new MyClass(otherInstance)); ... myInstance->DoSomethingImportant();
MyClass获取另一个类的共享指针,并将其存储在m_otherClass数据成员中.
在DoSomethingImportant方法中,MyClass实例执行许多重要的操作,包括将自己注册为m_otherClass上的观察者,如下所示:
m_otherClass-> registerObserver(本);
问题是registerObserver方法的定义如下:
void registerObserver(std :: shared_ptr observer);
它需要一个共享指针,但’this’是一个原始指针,而不是一个共享指针.
我看到三种解决方法:
>找到将普通指针转换为共享指针的技巧(参见问题convert pointer to shared_ptr),但该问题的答案仅建议复制共享指针,而不是如何将指针实际转换为共享指针.
>将共享指针传递给我们自己的方法,如下所示:“myInstance-> DoSomethingImportant(myInstance);”这似乎有点愚蠢.
>将观察者部分放入一个单独的类中.这看起来有点矫枉过正,可能会使课程更难理解.
这个问题很明显,共享指针只是C的附加组件(我不认为你在C#(或一般的.Net)和Java等其他语言/环境中遇到同样的问题).
关于如何处理这种情况的任何其他建议或窍门?
解决方法
你需要的可能是enable_shared_from_this和shared_from_this这些设施.文档是
here
请注意,在构造函数完全完成且对象已由另一个shared_ptr拥有之前,您不能使用shared_from_this.
struct test : boost::enabled_shared_from_this<test> { test() { // shared_from_this(this); // error,still not owned by another shared_ptr } boost::shared_ptr<test> shared() { return shared_from_this(this); } }; int main() { test * t = new test; // boost::shared_ptr<test> p = t->shared(); // error,not yet owned by other shared_ptr boost::shared_ptr<test> owner( t ); boost::shared_ptr<test> p = t->shared(); // [*] ok,"owner" owns the object }
[*]这部分示例很愚蠢,您可以将所有者复制到p中,而不是调用该方法.只是在测试方法中调用shared_from_this时可以注意到它.