将多个指针分配给同一对象并检查地址后,只有一个指针指向正确的指针

After assigning multiple pointers to the same object and checking the addresses, only one of the pointers points to the right one

本文关键字:指针 有一个 地址 检查 分配 对象      更新时间:2023-10-16

我正在为C++类制作游戏,但指针有问题。 为了给角色装备物品,我为不同的可穿戴物品类型创建了 8 个指针。我还创建了一个名为 noItem 的类,它继承了所有项目类型并将所有属性初始化为零。 当我创建角色时,我创建了一个noItem的实例,并使所有指针都指向该实例,但是当我检查指针指向的地址时,只有一个指向noItem实例的地址。

尝试重新排列指针赋值的顺序,无论我何时将其指向noItem的实例,其余指针指向接近noItem实例地址的地址,但实际上从未存在过,它始终是具有正确指针的同一指针。 我什至尝试为每个项目类型制作一个 noItem 实例,但发生了同样的问题。

class parent1 {
};
class parent2 {
};
class child : public parent1, public parent2 {
};

int _tmain(int argc, _TCHAR* argv [])
{
parent1 *p1;
parent2 *p2;
child a;
p1 = &a;
p2 = &a;
cout << &a << endl;
cout << p1 << endl;
cout << p2 << endl;
system("pause");
}

在此示例中,p1 指向 &a,但 p2 指向另一个地址。 如果我更改子类从父类继承的顺序,p2 将指向 &a,但 p1 将指向另一个地址。 为什么会这样?

你说你这样做了

class Helm {}
class Legs {}
class Sleeves {}
class noItem : public Helm, public Legs, public Sleeves {}

相反,你应该做一些类似的事情

class Item {}
class Helm : public Item {}
class Legs : public Item {}
class Sleeves : public Item {}

正如你所说,你的noItem类派生自许多其他类型,例如 Helmet .这意味着在noItem对象的某个地方,有一个Helmet子对象。它可能在开头,但那里只能有一个子对象(通常是第一个基类,忽略复杂的继承方案(。

查看您的指针。有一个你声称是"正确的"。这指向第一个基类子对象。现在计算sizeof(*correctPointer).这将告诉您第二个子对象可以从哪里开始。可能会有一些填充,但总的来说,这正是神秘的区别。

向项基类添加向量或指针列表。 根据需要将项目分配并插入到列表中。不要对一定数量的项目进行硬编码。缺少物品最好表现为什么都没有。

相关文章: