class Quote { /* ... */ };
void display(const Quote&) { /* ... */ }
}
//
class Bulk_item : public NS::Quote { /* ... */ };
int main() {
Bulk_item book1;
display(book1);
return 0;
}
Аргумент book1
функции display()
имеет тип класса Bulk_item
. Функциями-кандидатами для этого вызова функции display()
будут не только функции с объявлениями, видимыми на момент вызова, но и те, которые объявлены в пространстве имен класса Bulk_item
и его базового класса Quote. Таким образом, функция display(const Quote&)
, объявленная в пространстве имен NS
, будет добавлена в набор функций кандидатов.
using
Чтобы уяснить взаимодействие объявлений using и перегрузки, важно помнить, что объявление using объявляет только имя, а не конкретную функцию (см. раздел 15.6):
using NS::print(int); //
using NS::print; //
Когда объявление using
используется для функции, все версии этой функции переводятся в текущую область видимости.
Объявление using
подключает все версии перегруженной функции, чтобы не нарушить интерфейс пространства имен. Ведь предоставляя разные версии функции, автор библиотеки имел на то весомую причину. Разрешив пользователям игнорировать некоторые (но не все) функции из набора перегруженных версий, можно получить довольно странное поведение программы.
Функции, предоставленные объявлением using
, перегружают любые другие объявления одноименных функций, уже находящихся в данной области видимости.
Если объявление using
расположено в локальной области видимости, эти имена скрывают существующие объявления для того имени во внешней области видимости. Если объявление using
вводит функцию в область видимости, в которой уже есть функция с тем же именем и тем же списком параметров, объявление using
окажется ошибочным. В противном случае объявление using
создаст дополнительный перегруженный экземпляр данной функции. В результате набор функций-кандидатов увеличится.
using
Директива using
переводит члены пространства имен в окружающую область видимости. Если имя функции пространства имен совпадает с именем функции той области видимости, в которую помещено пространство имен, эта функция будет добавлена в набор перегруженных функций.
namespace libs_R_us {
extern void print(int);
extern void print(double);
}
//
void print(const std::string &);
//
//
using namespace libs_R_us;
//
//
//
//
void fooBar(int ival) {
print("Value: "); //
print(ival); //
}
В отличие от объявления using
, не будет ошибки, если директива using
предоставит функцию с теми же параметрами, что и у существующей функции. Подобно другим конфликтам, вызванным директивами using
, не будет никаких проблем, если не пытаться вызывать функцию без уточнения, относится ли она к пространству имен или к текущей области видимости.
using
Если в коде присутствует несколько директив using
, частью набора функций-кандидатов станут соответствующие функции из каждого пространства имен.
namespace AW {
int print(int);
}
namespace Primer {
double print(double);
}
//
//
using namespace AW;
using namespace Primer;
long double print(long double);
int main() {
print(1); //
print(3.1); //