0

我对 C++ 相当陌生,并且使用类似于以下代码的指针分配不断出现分段错误,我知道这意味着我正在访问尚未分配的内存,但我看不到在哪里:

我有两节课:

class ClassA{ //class a decl.
  ClassB** oArray;
  unsigned int x;
 public:
  ClassA(unsigned int X);
  void oMember(ClassB* classb);
}


ClassA::ClassA(unsigned int X){ //Constructor for class a
  x = X;
  oArray = new ClassB* [x];

 for (unsigned int i = 0; i < x; i++){
        oArray = NULL; 
    }
}

class ClassB{ //rough decl of class B
  public:
   getId();
}

我有一个类成员函数,它接收指向另一个类的指针,如下所示:

void ClassA::oMember(ClassB* classb){
   unsigned int cID = classb.getId(); //defined in class b
   oArray[cID] = classb; //if cID is less than x defined in constructor, is this legal?
}

我只想将数组的 cIDth 成员指向 classb。

我不断收到与上述类似的分配错误。我不太清楚为什么,我打印了 cID,它肯定小于我们在 ClassA 的构造函数中声明的数组的大小。

为什么该分配是非法的,或者为什么我会遇到分段错误?

4

3 回答 3

1

正如我们在聊天中意识到的那样,我只是将问题记录在这里以供参考。

问题出在片子上

RegisteredVMs = new VendingMachine *[nVendingMachines];
for (unsigned int i = 0; i < nVendingMachines; i++){
   RegisteredVMs = NULL; 
}

RegisteredVMs 被分配并立即设置为 NULL。稍后在导致 seg 的 VMregister() 函数中访问该指针。过错。

指针很难而且很容易出错。只有在没有其他方法的情况下才使用它们。既然这是一个家庭作业问题,而且你说你在界面上没有发言权,我看到你必须使用它们。

于 2012-07-22T17:39:37.490 回答
1

我认为您应该将ClassA更改为

class ClassA{
  std::map<int, std::shared_ptr<ClassB> > mMap;

 public:
  ClassA();
};

现在 A 类不需要知道数组大小,mMap 将确保您没有非常稀疏的数组。

于 2012-07-22T16:28:25.697 回答
0

我认为classb.getId()应该classb->getId()改为只要classb是一个指针。好吧,那应该是编译器错误,我认为这不是您遇到分段错误的原因。

你确定你ClassA用那个特定的构造函数实例化了吗?如果不是,xandoArray可能不会被初始化。

我没有你的代码。但是当我修改你的代码段时,我没有发现分段错误或编译器警告。

class ClassB {
public:
    int getId();
};

class ClassA {
    ClassB** oArray;
    unsigned int x;
public:
    ClassA(unsigned int X);
    void oMember(ClassB* classb);
};

int ClassB::getId() {
    return 0;
}

ClassA::ClassA(unsigned int X) {
    x = X;
    oArray = new ClassB* [x];
}

void ClassA::oMember(ClassB* classb) {
    unsigned int cID = classb->getId();
    oArray[cID] = classb;
}

int main(int argc, char** argv) {
    ClassA a(12);
    ClassB b;
    a.oMember(&b);
    return 0;
}
于 2012-07-22T16:42:40.980 回答