C++中using的作用


[轉自] http://www.cnblogs.com/yuaqua/archive/2011/10/22/2219991.html

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聲明將名字加入作用域之后,派生類只需要重定義本類型確實必須定義的那些函數,對其他版本可以使用繼承的定義。

下面是代碼示例:

復制代碼
#include <iostream>
using namespace std;

class Base
{
public:
int menfcn(){cout<<"Base function"<<endl; return 0;}
};
class Derived : Base
{
public:
using Base::menfcn;//using聲明只能指定一個名字,不能帶形參表
int menfcn(int);
};

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();//暫停程序執行
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM