1.在當前文件中引入命名空間
這是我們最熟悉的用法,例如:using namespace std;
2.在子類中使用 using 聲明引入基類成員名稱(參見C++ primer)
在private或者protected繼承時,基類成員的訪問級別在派生類中更受限:
class Base {
public:
std::size_t size() const { return n; }
protected:
std::size_t n;
};
class Derived : private Base { . . . };
在這一繼承層次中,成員函數 size 在 Base 中為 public,但在 Derived 中為 private。為了使 size 在 Derived 中成為 public,可以在 Derived 的 public
部分增加一個 using 聲明。如下這樣改變 Derived 的定義,可以使 size 成員能夠被用戶訪問,並使 n 能夠被 Derived的派生類訪問:
class Derived : private Base {
public:
using Base::size;
protected:
using Base::n;
// ...
};
另外,當子類中的成員函數和基類同名時,子類中重定義的成員函數將隱藏基類中的版本,即使函數原型不同也是如此(隱藏條件見下面)。
如果基類中成員函數有多個重載版本,派生類可以重定義所繼承的 0 個或多個版本,但是通過派生類型只能訪問派生類中重定義的那些版本,所以如果派生類想通過自身類型使用所有的重載版本,則派生類必須要么重定義所有重載版本,要么一個也不重定義。有時類需要僅僅重定義一個重載集中某些版本的行為,並且想要繼承其他版本的含義,在這種情況下,為了重定義需要特化的某個版本而不得不重定義每一個基類版本,可能會令人厭煩。可以在派生類中為重載成員名稱提供 using 聲明(為基類成員函數名稱而作的 using 聲明將該函數的所有重載實例加到派生類的作用域),使派生類不用重定義所繼承的每一個基類版本。一個 using 聲明只能指定一個名字,不能指定形參表,使用using聲明將名字加入作用域之后,派生類只需要重定義本類型確實必須定義的那些函數,對其他版本可以使用繼承的定義。
“隱藏”是指派生類的函數屏蔽了與其同名的基類函數,規則如下:
1、如果派生類的函數與基類的函數同名,但是參數不同。此時,不論有無virtual關鍵字,基類的函數將被隱藏(注意別與重載混淆)
2、如果派生類的函數與基類的函數同名,並且參數也相同,但是基類函數沒有virtual關鍵字。此時,基類的函數被隱藏(注意別與覆蓋混淆)
#include "StdAfx.h"
#include <iostream>
using namespace std;
class Base
{
public:
void menfcn()
{
cout<<"Base function"<<endl;
}
void menfcn(int n)
{
cout<< cout<<"Base function with int"<<endl;
}
};
class Derived : Base
{
public:
using Base::menfcn;//using聲明只能指定一個名字,不能帶形參表
int menfcn(int)
{ cout<< cout<<"Derived function with int"<<endl; }
};
int main()
{ Base b;
Derived d;
b.menfcn();
d.menfcn();//如果去掉Derived類中的using聲明,會出現錯誤:error C2660: 'Derived::menfcn' : function does not take 0 arguments std::cin.ignore(std::cin.gcount()+1);//清空緩沖區 std::cin.get();//暫停程序執行
}