c++ - 传递派生类指针 C++ 时的运行时错误

标签 c++ pointers vector segmentation-fault

当我尝试将指向一个对象的指针添加到另一个对象的实例中的 vector 时,我遇到了段错误。我一次向 vector 添加多个指针,第一个有效,但第二次尝试一直抛出段错误。

class Observer {
  Observer();
  observe();
};

class Subject {
  std::vector<Observer*> *observers;
  std::string name;

  Subject();
  virtual std::string getName();
  virtual void addObserver(Observer *observer) {
    observers->push_back(observer);
  }
};

class Base : public Subject {
  Base(std::string newName) { name = newName; }
};

class Derivative : public Subject, public Observer {
  float a;
  float b;
  float c;
  Derivative(a, b, c) { this->a = a; this->b = b; this->c = c; }

};

class Board : public Base {
   Base *base;

   Board(std::string newName, Base *newBase) { name = newName; base = newBase; }

   void initializeDerivatives(int start, int end) {
     for (int i = start; i <= end; ++i) {
       addObserver(new Derivative(start, start + 1, start + 2)); //works
       base->addObserver(new Derivative(start, start + 1, start + 2)); //THIS WORKS
       addObserver(new Derivative(start, start + 2, start + 3)); //works
       base->addObserver(new Derivative(start, start + 2, start + 3)); //seg fault here
     }
   }
};

int main() {
  Base myBase("MYBASE");
  Board myBoard("MYBASE", myBase);

  myBoard.initializeDerivatives(1, 10);
}

当我将 myBoard 和 myBase 声明为指针时,我早些时候遇到了段错误: Base* myBase = new Base("MYBASE"); Board* myBoard = new Board("MYBASE", myBase);

我不确定为什么会这样,因为我认为使用 new 运算符实际上会初始化对象的实例。将其更改为实际对象仍然允许我添加一个指向观察者 vector 的指针,但第二个指针不起作用。有什么想法吗?

最佳答案

class Subject 中,您应该更改为:

std::vector<Observer*> *observers;

对此:

std::vector<Observer*> observers;

作为指针,您的代码不会显示该指针在任何地方被初始化。如果它在构造函数中 初始化,您可能会发生内存泄漏,因为 Subject 没有析构函数。

关于c++ - 传递派生类指针 C++ 时的运行时错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15484018/

相关文章:

c - 取消引用 void ** 参数时出现段错误

C - 访问结构数组

c++ - 函数不断返回相同的值

c++ - std::vector 何时重新分配其内存数组?

c++ - Indent 向 const 方法添加额外的 const

c++ - 如何使用带有附加参数的 for_each?

c++ - 使用 for 循环是否比在 C++ 中将内容保存在 vector 中更快?

c++ - 如何从 DLL 与 C++ 中的调用应用程序通信

c - 在 Pthreads 中使用 malloc

c++ - 真正的动态 vector 类型