下面的代码给出输出为136.但我无法理解前两个地址比较是如何相等的.感谢任何帮助以理解这一点.谢谢.
#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 d;
A *b1 = &d;
B *b2 = &d;
const int a = (reinterpret_cast<char *>(b1) == reinterpret_cast<char *>(&d)) ? 1 : 2;
const int b = (b2 == &d) ? 3 : 4;
const int c = (reinterpret_cast<char *>(b1) == reinterpret_cast<char *>(b2)) ? 5 : 6;
std::cout << a << b << c << std::endl;
return 0;
}
Run Code Online (Sandbox Code Playgroud)
当您像示例中那样使用多重继承时,第一个基类和派生类共享相同的基地址。您继承的其他类根据所有前面的类的大小按偏移量顺序排列。比较结果为真,因为d和 的基地址b1相同。
在您的情况下,如果 的大小A是 4 字节,那么B将从 + 4 字节的基地址开始A。当您这样做时,B *b2 = &d;编译器会计算偏移量并相应地调整指针值。
当您执行b2 == &d从类型“C”到类型“B”的隐式转换时,会d在比较完成之前执行。此转换会调整指针值的偏移量,就像在赋值中一样。