Скрытие имени и доступ к не-виртуальной функции базового класса (синтаксис)

В следующем коде:

#include <iostream>

class A
{
public:
    void f( float x ) { std::cout << 1; }
    void g() { std::cout << 11; }
};

class B : public A
{
public:
    void f( char x ) { std::cout << 2; }
    void g() { std::cout << 22; }
};

int main()
{
    B b;
    b.A::f( 0 );
    b.A::g();

    return 0;
}

Разве это имя не скрывается? И где этот синтаксис определен в Стандарте (C++11 или C++03, не имеет значения, он кажется одинаковым для обоих стандартов)?

Я не знал, что это вообще возможно, это первый раз, когда я вижу такой синтаксис (увидел его здесь впервые: почему я не могу получить доступ к функции класса A в следующем коде?)

1 ответ

Решение

Да, это имя скрывается. следовательно, это не перегрузка (и не переопределение) . раздел 13.2 Declaration matching в N3485 объясняет об этом.

13.2 Declaration matching

 1   Two function declarations of the same name refer to the same function if they are in
the same scope and have equivalent parameter declarations (13.1). A function member of
a derived class is not in the same scope as a function member of the same name in a base class. 

[ Example:


struct B {
int f(int);
};

struct D : B {
int f(const char*);
};
Here D::f(const char*) hides B::f(int) rather than overloading it.
void h(D* pd) {
pd->f(1); // error:
// D::f(const char*) hides B::f(int)
pd->B::f(1); // OK
pd->f("Ben"); // OK, calls D::f
}

- конец примера]

Другие вопросы по тегам