#include <iostream>
class Base
{
protected:
void somethingProtected()
{
std::cout << "lala" << std::endl;
}
};
class Derived : public Base
{
public:
void somethingDerived()
{
Base b;
b.somethingProtected(); // This does not compile
somethingProtected(); // But this is fine
}
};
int main()
{
Derived d;
d.somethingDerived();
return 0;
}
Я думал, что, возможно, только защищенные члены this
могут использоваться, а защищенные члены других экземпляров навсегда недоступны.
Но:
class Derived : public Base
{
public:
void somethingDerived(Derived& d)
{
d.somethingProtected(); // This compiles even though d is
// potentially a different instance
}
void somethingDerived(Base& b)
{
b.somethingProtected(); // This does not
}
};
Я чувствую себя отвратительным от этого, так как я некоторое время программировал на С++, но я не мог найти объяснения этого поведения.
EDIT:
Не имеет значения, является ли он одним и тем же или другим экземпляром:
int main()
{
Derived d1, d2; // Two different instances
d1.somethingDerived(d2); // This compiles fine
d1.somethingDerived(d1); // This compiles fine
return 0;
}
EDIT2:
Похоже, что когда речь идет о правах доступа, вообще не имеет значения, что используется экземпляр для класса:
class Base
{
public:
void something(Base& b) // Another instance
{
++b.a; // But can enter private members
}
private:
int a;
};