Poniższy kod podaje dane wyjściowe jako 136. Nie mogłem jednak zrozumieć, w jaki sposób pierwsze dwa porównania adresów są równe. Doceniamy każdą pomoc, aby to zrozumieć. Dziękuję Ci.interpretacja adresów obiektów za pomocą reintepret_cast
#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;
}
Dlaczego używasz tutaj 'reinterpret_cast'? Czego oczekujesz od używania 'char *' dla typu wskaźnika na twojej architekturze? –
nie jest to aplikacja działająca w czasie rzeczywistym. To było z testu C++. Chcę tylko zrozumieć, jak reinterpret_cast interpretuje adresy w tym konkretnym przypadku. – irappa