当我尝试从嵌套 class 访问外部 class 的成员数据时,为什么会出现分段错误?

Why do I get segmentation fault when I try to access member data of outer class from nested class?

我有一个 class 外部嵌套 class 内部。 Inner 有一个方法 'print' 试图访问 class Outer 的数据成员。代码编译正常,但是当我尝试 运行 程序时出现分段错误。

#include <iostream>

class Outer{
public:
  Outer();
  ~Outer();

  class Inner{
  public:
    Inner(Outer *parent){}
    void print(){std::cout<< parent-> data <<std::endl;}
  private:
    Outer *parent;
  };
  Inner *obj;

private:
  int data;
};

Outer::Outer(): data(99), obj(new Inner(this)){}
Outer::~Outer(){delete obj;}

int main(){
  Outer outer;
  outer.obj->print();
  return 0;
}

我不确定是什么问题,因为我已经将 'this' 指针传递给内部对象。

代码是使用 c++11 标志使用 g++4.8.2 编译的。

您没有在 Inner 构造函数中存储指向 Outer class 的指针:

Inner(Outer *parent) : parent(parent) {}

此外,如果您使用 C++11,这可能是使用智能指针的好案例。

您没有在

中对parent做任何事情
Inner(Outer *parent){}

您需要Inner构造函数中的parent成员

Inner(Outer *parent_) : parent(parent_){}

您必须打开编译器警告并注意它们。在这种情况下,编译器能够查明确切的错误:

 Inner(Outer *parent){}
warning: unused parameter 'parent' [-Wunused-parameter] In constructor 'Outer::Outer()':

(确切的警告消息可能有所不同,但如果您不使用一些较低的默认警告级别来阻止它们这样做,所有主要编译器都能够检测到这一点。)

当您将 parent 成员变量置于未初始化状态时,以下行会调用未定义的行为,因为您试图从变量中读取:

 void print(){std::cout<< parent-> data <<std::endl;}

必须初始化成员变量:

Inner(Outer *parent) : parent(parent) {}

但这不是唯一的问题。还有这个:

18:7: warning: 'Outer::data' will be initialized after [-Wreorder]
15:10: warning: 'Outer::Inner* Outer::obj' [-Wreorder]
21:1: warning: when initialized here [-Wreorder]

您只需按如下方式更改顺序即可解决此问题:

Outer::Outer(): obj(new Inner(this)), data(99) {}