【问题标题】:Segmentation fault when accessing QSharedPointer object访问 QSharedPointer 对象时出现分段错误
【发布时间】:2015-10-26 17:18:45
【问题描述】:

我已经编写了一个小的示例应用程序代码,如下所示。

#include <QCoreApplication>
#include <QSharedPointer>
#include <QDebug>

class INav
{
public:
    virtual int getdata() = 0;
    virtual void setdata(int a) = 0;
};

class Nav : public INav
{
    int i;
public:
    Nav(int a) : i(a) {}

    int getdata() { return i;}
    void setdata(int a) { i = a; }
};

class CMain
{
    Nav* nav;

public:
    CMain(Nav* n) : nav(n) {}
    QSharedPointer<INav> getINav()
    {
        QSharedPointer<Nav> n(nav);
        return n.staticCast<INav>();
    }
};

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    QSharedPointer<CMain> m(new CMain(new Nav(1)));

    int i = 0;
    while (++i != 3)
    {
        QSharedPointer<INav> nav = m->getINav();
        qDebug() << nav.data()->getdata();
    }

    return a.exec();
}

当我第二次打印调试消息时,它会显示分段错误和应用程序崩溃。 根据 QSharedPointer 的文档,它可能在访问元素后第一次删除指针。

我想要 QSharedPointer nav = m->getINav();在while循环中 本身,因为这是我真实场景的虚拟应用程序 问题。

我不知道如何做到这一点,任何帮助将不胜感激。提前致谢。

【问题讨论】:

  • 您的假设是正确的,即当QSharedPointer&lt;INav&gt; nav 超出范围时,指针将被删除。为什么不把CMain中的指针作为共享指针存储呢?
  • @NathanOliver 它穿了 :) 谢谢,

标签: c++ qt polymorphism qsharedpointer


【解决方案1】:

您不能用同一个指针实例化多个shared_ptr (QSharedPointer) 的对象。在这种情况下,第一个销毁的共享指针也会销毁拥有的对象。

只有一个共享指针应该被真实指针初始化。然后要复制该指针,一个新的共享指针应该由另一个拥有该对象的共享指针初始化。

这里CMain 类应该保留QSharedPointer&lt;Nav&gt; 而不是纯指针。吸气剂应提供该QSharedPointer 的副本。在这种情况下,对象Nav 只会在其最后一个所有者QSharedPointer 被销毁时才会被销毁。

【讨论】:

    猜你喜欢
    • 2014-05-31
    • 1970-01-01
    • 1970-01-01
    • 2011-03-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-02-28
    相关资源
    最近更新 更多