ARM交叉编译,多重继承的分段错误

ing*_*ram 5 c++ linux gcc arm multiple-inheritance

我有一个使用多重继承和多态的C++应用程序.它在x86_64-linux上正常工作但在arm-linux上我遇到了分段错误.

我写了一个简单的测试来重新创建问题:

#include <list>
#include <iostream>

class SmartObject
{
    public:

    // removing this destructor makes it work in ANY way
    virtual ~SmartObject(){
    }

    void method(void) {}
};

class IMyInterface
{
    public:

    // removing this destructor have no effect (fails)
    virtual ~IMyInterface(){
    }

    virtual std::list<int> getList() = 0;
};

class MyObject :  public SmartObject, public virtual IMyInterface
{
    public:

    MyObject()
    {
        list.push_back(4);
        list.push_back(5);
    }

    virtual std::list<int> getList() {
        return list;
    }

    std::list<int> list;
};

int main()
{
    IMyInterface * ip = new MyObject();
    std::list<int> list_clone = ip->getList();
    std::cout << list_clone.size() << std::endl;
    delete ip;
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

此代码在x64-linux和win32(也在其他嵌入式平台上)上正常工作,但在arm-linux上,它在调用list_clone.size()时会导致分段错误,因为复制的列表具有不正确的尾部指针.

我试过gcc 4.8.3和4.9.1,但我看到了同样的行为.目标架构是具有硬浮点的ARM cortex-A处理器.

任何的想法?

实际上我找到了两种独立的方法来使它工作:

  1. 通过删除SmartObject析构函数,但这在整个应用程序中是不可行的.
  2. 通过以这种方式声明MyObject(在SmartObject上虚拟并反转顺序):

class MyObject : public virtual IMyInterface, public virtual SmartObject

提前致谢

小智 -1

您还需要一个虚拟析构函数class MyObject。否则,您不能期望MyObject通过类型的指针正确地销毁实例IMyInterface