C++关键字作用总结

1、在当前文件中引入命名空间

2、在子类中使用using声明引入基类成员名称

在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。为了使之成为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();//暂停程序执行  }

 

posted @ 2014-10-15 12:34  liaotingpure  阅读(810)  评论(0编辑  收藏  举报