类函数和成员变量踩踏内存

Class function and member variable stomping memory

本文关键字:内存 变量 成员 类函数      更新时间:2023-10-16

我正在为iOS和Android的应用程序工作,我在我的c++代码中得到非常不同的结果。我遇到的问题是,进入一个函数是践踏成员变量是一个派生类。例如

int main()
{
   A** arrayOfA = new A[10];
   for (int i = 0; i < 10; ++i)
   {
      arrayOfA[i] = new D();
   }
   return 0;
};
class A
{
// Original code here. After this is the added function and member variable that breaks it
public:
   virtual u32 GetterFunction() = 0;
protected:
   u32 ProblemVariable;
};
class B : A
{
public:
   B(u32 index) { ProblemVariable = index }
   virtual u32 StompedGetter() = 0;
   virtual u32 GetterFunction() { return ProblemVariable; }
   void Initialize()
   {
      u32 sometimesBunkNumber = StompedGetter();
   }
protected:
   u32 StompedVariable;
};
class C : A
{
public:
   virtual u32 GetterFunction() { return 0; }
};
class D : B
{
   B() { Initialize(); }
   virtual StompedGetter() { return StompedVariable; }
}
class E : B
{
   virtual StompedGetter() { return 0; }
}

现在,这里的问题是,一切工作正常,直到我把成员变量和虚拟getter在类a中。当getter被调用时,它会随机给出一个床位号。它可能会工作2次,然后它会返回一个错误的数字(显然是从内存中的错误位置抓取)。函数是否是虚函数并不重要,但它是理想的解。最糟糕的是,这在iOS版本上运行良好,但在Android上却无法运行。只是作为一个澄清,它运行,直到它初始化类a的数组类B抱歉,如果这是非常模糊的,但任何和所有的帮助是赞赏的。提前感谢!

根据您所展示的代码,我唯一能想到的是

这一行
A** arrayOfA = new A[10];

应该改成

A** arrayOfA = new A*[10];

您描述的症状似乎表明您正在执行某种内存侵犯,并且将指向指向A的指针的指针数组处理为A的数组,然后通过对它们赋值D来访问这些A,可能会导致这种情况。在添加成员变量之前,它可能工作得很好,因为之前它只是一个空结构体(地址的大小)。现在sizeof(A) != sizeof(A*),你已经占用了你所有的内存