c++11中的using关键字

一般的using关键子我们都是用来声明当前文件的命名空间,比如标准库的命名空间std-> using namespace std;

但在C++11中,它的用处还有几个 1:取代typedef ,2:让父类同名函数在子类中以重载方式使用

以下是《深入理解c++11》的对1:的截图

img

以下是自己的实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//---------------------------------------test2 可以取代typedef了,而且更加灵活
using myIntVec = std::vector<int>;
void testUsing2()
{
myIntVec mvec = { 1, 2, 3, 4, 5 };
mvec.push_back(123);
for (int num : mvec)
printf("--- num:%d\n", num);

std::cout << is_same < std::vector<int>, myIntVec>::value << std::endl; // 1
}

template <typename T>
using MapStr = std::map<T, std::string>;
void testUsing3()
{
MapStr<int> intStrMap;
intStrMap.insert(make_pair(123, "aaa"));
intStrMap.insert(make_pair(456, "bbb"));

MapStr<std::string> strstrMap;
strstrMap.insert(make_pair("ccc", "ddd"));
strstrMap.insert(make_pair("eee", "fff"));
}

第二种用处,直接看代码注释吧

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//---------------------------------------test1
using namespace std;

class Base
{
public:
void menfcn()
{
cout << "Base function" << endl;
}

void menfcn(int n)
{
cout << "Base function with int" << endl;
}
//private:
// void menfcn(std::string _name) {}//会让基类using时报不可访问的错
};

class Derived : private Base
{
public:
using Base::menfcn;//using声明只能指定一个名字,不能带形参表,且基类的该函数不能有私有版本,否则编译报错
//using父类方法,主要是用来实现可以在子类实例中调用到父类的重载版本
int menfcn(int num)
{
cout << "Derived function with int : "<< num << endl;
return num;
}
};

/*
“隐藏”是指派生类的函数屏蔽了与其同名的基类函数,规则如下:
1、如果派生类的函数与基类的函数同名,但是参数不同。此时,不论有无virtual关键字,基类的函数将被隐藏(注意别与重载混淆)
2、如果派生类的函数与基类的函数同名,并且参数也相同,但是基类函数没有virtual关键字。此时,基类的函数被隐藏(注意别与覆盖混淆)
使用了using关键字,就可以避免1的情况,是的父类同名函数在子类中得以重载,不被隐藏
*/

void testUsing1()
{
Base b;
Derived d;
b.menfcn();
d.menfcn();//如果去掉Derived类中的using声明,会出现错误:error C2660: 'Derived::menfcn' : function does not take 0 arguments
d.menfcn(123);
/*
Base function
Base function
Derived function with int : 123
*/
}