1. 程式人生 > >C++ using關鍵字作用 (過載父類函式)

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