Как уже было сказано, это создает две отдельные переменные:
A::x;
// and
B::x;
На самом деле, если вы попытаетесь использовать только 'x' в методе B, будет использоваться только более точное определение объема, пока вы не станете более точным:
#include <iostream>
class A
{
protected:
static int x;
public:
A() { x = 7; }
};
int A::x = 22;
class B:A
{
static const int x = 42;
public:
int a_x() const { return A::x; }
int b_x() const { return B::x; }
int my_x() const { return x; } // here we get the more local variable, that is B::x.
};
int main()
{
B b;
std::cout << "A::x = " << b.a_x() << std::endl;
std::cout << "B::x = " << b.b_x() << std::endl;
std::cout << "b's x = " << b.my_x() << std::endl;
std::cin.ignore();
return 0;
}
Выходы:
A::x = 7
B::x = 42
b's x = 42
Кто-то упомянул, что доступность может ограничивать доступность: закрытие базовой переменной не сделает ее доступной для дочернего класса.
Однако, если переменная должна быть защищенной или общедоступной, используйте явный метод доступа или положитесь на правило локальной области действия, которое я только что продемонстрировал.