为什么指向同一个对象的指针有不同的值?

use*_*951 10 c++ pointers memory-address

我有这段代码:

#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;

    std::cout << (long)b1 << std::endl <<(long)b2<< std::endl;
}
Run Code Online (Sandbox Code Playgroud)

编译并运行时,它会产生以下输出:

140734705182320
140734705182328
Run Code Online (Sandbox Code Playgroud)

不完全清楚为什么指向同一地址(&d)的不同指针具有不同的值.

提前致谢.

Mik*_*our 12

C对象的内存布局类似于:

A base_object_1;
B base_object_2;
char m_c;
Run Code Online (Sandbox Code Playgroud)

两个基础对象具有不同的地址; A将(通常)具有与完整对象相同的地址,但是B(通常)不会.当然,他们不能拥有彼此相同的地址,除非至少有一个是空的.

因此,将指向完整对象的指针转换为指向其中一个基础对象的指针必须更改指针值,以便指向正确的地址.