ВУЗ:
Составители:
Рубрика:
18
f(char[]); // идентично f(char*);
f(char[7]); // идентично f(char*);
f(char[9]); // идентично f(char*);
g(char(*)[10]);
g(char[5][10]); // идентично g(char(*)[10]);
g(char[7][10]); // идентично g(char(*)[10]);
g(char(*)[20]); // отлично от g(char(*)[10]);
Сопоставление описаний
Два описания функций с одинаковыми именами относятся к одной и той же
функции, если они находятся в одной области видимости и имеют идентичные типы
параметров. Функция-член производного класса относится к иной области видимости,
чем функция-член базового класса с тем же именем. Рассмотрим пример:
class B {
public:
int f(int);
};
class D : public B {
public:
int f(char*);
};
Здесь D::f(char*) скорее скрывает B::f(int), чем перегружает эту
функцию.
void h(D* pd)
{
pd->f(1); // ошибка: D::f(char*) скрывает B::f(int)
pd->B::f(1); // нормально
pd->f("Ben"); // нормально, вызов D::f
}
Функция, описанная локально, находится в иной области видимости, чем функ-
ция с файловой областью видимости.
int f(char*);
void g()
{
extern f(int);
f("asdf"); // ошибка: f(int) скрывает f(char*) поэтому
// в текущей области видимости нет f(char*)
}
Для разных вариантов перегруженной функции-члена можно задать разные пра-
вила доступа, например:
class buffer {
private:
char* p;
int size;
protected:
buffer(int s, char* store) { size = s; p = store; }
// ...
public:
buffer(int s) { p = new char[size = s]; }
18
f(char[]); // идентично f(char*);
f(char[7]); // идентично f(char*);
f(char[9]); // идентично f(char*);
g(char(*)[10]);
g(char[5][10]); // идентично g(char(*)[10]);
g(char[7][10]); // идентично g(char(*)[10]);
g(char(*)[20]); // отлично от g(char(*)[10]);
Сопоставление описаний
Два описания функций с одинаковыми именами относятся к одной и той же
функции, если они находятся в одной области видимости и имеют идентичные типы
параметров. Функция-член производного класса относится к иной области видимости,
чем функция-член базового класса с тем же именем. Рассмотрим пример:
class B {
public:
int f(int);
};
class D : public B {
public:
int f(char*);
};
Здесь D::f(char*) скорее скрывает B::f(int), чем перегружает эту функцию.
void h(D* pd)
{
pd->f(1); // ошибка: D::f(char*) скрывает B::f(int)
pd->B::f(1); // нормально
pd->f("Ben"); // нормально, вызов D::f
}
Функция, описанная локально, находится в иной области видимости, чем функ-
ция с файловой областью видимости.
int f(char*);
void g()
{
extern f(int);
f("asdf"); // ошибка: f(int) скрывает f(char*) поэтому
// в текущей области видимости нет f(char*)
}
Для разных вариантов перегруженной функции-члена можно задать разные пра-
вила доступа, например:
class buffer {
private:
char* p;
int size;
protected:
buffer(int s, char* store) { size = s; p = store; }
// ...
public:
buffer(int s) { p = new char[size = s]; }
Страницы
- « первая
- ‹ предыдущая
- …
- 16
- 17
- 18
- 19
- 20
- …
- следующая ›
- последняя »
