C++中using的作用

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

而在c++11中,using又有了新的含義

定義別名
template<typename T>
using Tlist = std::list<T>;
using Tlist = std::list<char>;
using df = void(*)();//等價於typedef void(*df)()

使用外部構造
using A::A;

引入外部類型
using typename A;


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章