using一直都是关键词,但是C++11对其赋予了新的功能。
using在C++11之前主要用于名字空间、类型、函数与对象的引入,实际上是去除作用域的限制。
常用如:
using namespace std; //引用命名空间
using std::iostream; //引用类型
using std::to_string; //引用函数
using std::cout;//引用对象
值的注意的用法是可以通过using来允许子类声明基类成员名称
class A
{
public:
int v;
};
class B: private A
{
public:
using A::v;
void fun()
{
cout<<v<<endl;
}
};
当子类中的成员函数和基类同名时,子类中重定义的成员函数将隐藏基类中的版本,即使函数原型不同也是如此。
如果基类中成员函数有多个重载版本,派生类可以重定义所继承的 0 个或多个版本,但是通过派生类型只能访问派生类中重定义的那些版本,所以如果派生类想通过自身类型使用所有的重载版本,则派生类必须要么重定义所有重载版本,要么一个也不重定义。有时类需要仅仅重定义一个重载集中某些版本的行为,并且想要继承其他版本的含义,在这种情况下,为了重定义需要特化的某个版本而不得不重定义每一个基类版本,可能会令人厌烦。可以在派生类中为重载成员名称提供 using 声明(为基类成员函数名称而作的 using 声明将该函数的所有重载实例加到派生类的作用域),使派生类不用重定义所继承的每一个基类版本。一个 using 声明只能指定一个名字,不能指定形参表,使用using声明将名字加入作用域之后,派生类只需要重定义本类型确实必须定义的那些函数,对其他版本可以使用继承的定义。
“隐藏”是指派生类的函数屏蔽了与其同名的基类函数,规则如下:
1、如果派生类的函数与基类的函数同名,但是参数不同。此时,不论有无virtual关键字,基类的函数将被隐藏(注意别与重载混淆)
2、如果派生类的函数与基类的函数同名,并且参数也相同,但是基类函数没有virtual关键字。此时,基类的函数被隐藏(注意别与覆盖混淆)
而从C++11开始,可以使用using代替typedef,给类型命名:
typedef int ll;
using ll = int;
这两行的效果是一样的,这种简单情况看起来using新增加的功能没有什么特殊,但是 using现在可以支持对模板的重命名: