【发布时间】:2014-12-15 13:31:15
【问题描述】:
#include <iostream>
class A
{
public:
A() : m_i(0) { }
protected:
int m_i;
};
class B
{
public:
B() : m_d(0.0) { }
protected:
double m_d;
};
class C
: public A
, public B
{
public:
C() : m_c('a') { }
private:
char m_c;
};
int main()
{
C c;
A *pa = &c;
B *pb = &c;
const int x = (pa == &c) ? 1 : 2;
const int y = (pb == &c) ? 3 : 4;
const int z = (reinterpret_cast<char*>(pa) == reinterpret_cast<char*>(pb)) ? 5 : 6;
std::cout << x << y << z << std::endl;
return 0;
}
这段代码打印出136,这表明第一个相等是正确的,第二个相等但不是第三个。由于pa 和pb 都设置为&c,所以前两个是有道理的,但是为什么第三个相等是假的呢?
我在 Visual C++ 2012 中运行此代码并使用调试器检查地址:
pa == 0x003bfc90
pb == 0x003bfc98
&c == 0x003bfc90
显然,pa 和 pb 不指向同一个地址,这意味着第三个相等性应该为假(确实如此)。但是为什么前两个是真的呢?你能解释一下这里发生了什么吗?
【问题讨论】:
-
编译器会根据类型自动将偏移量添加到指针位置。您的演员可以防止这种情况发生。
标签: c++ class pointers inheritance memory-address