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

“隱藏”是指派生類的函數屏蔽了與其同名的基類函數,規則如下:

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


免責聲明!

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



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