C++ 覆盖和隐藏学习

#include "stdafx.h"
#include<iostream>
using namespace std;

class Base{
public:
	virtual void xfn(int i)
	{
		cout<<"base::xfn(int i)"<<i<<endl;
	}

	void yfd(float f)
	{
		cout<<"base:: yfn(float)"<<endl;
	}

	void zfn()
	{
		cout<<"base::zfn()"<<endl;
	}
};

class Derived:public Base
{
public:
	void xfn(int i)//基类中有virtual修饰且参数和名字相同 则是覆盖
	{
		cout<<"derived::xfn(int i)"<<i<<endl;
	}

	void yfd(int  f)//隐藏基类函数同名参数不同 不管有,基类没有virtual修饰都是隐藏
	{
		cout<<"derived:: yfn(int f)"<<endl;
	}

	void zfn()//隐藏基类函数(同名且参数相同 但没有virtual修饰)
	{
		cout<<"derived::zfn()"<<endl;
	}

};
int _tmain(int argc, _TCHAR* argv[])
{
	Derived d;
	Base *pB = &d;
	Derived *pD = &d;

	pB->xfn(5);
	pD->xfn(10);

	d.yfd(2);
	d.yfd(3);
	return 0;
}

重载(overload): 必须在一个域中,函数名称相同但是函数参数不同,重载的作用就是同一个函数有不同的行为,因此不是在一个域中的函数是无法构成重载的,这个是重载的重要特征覆盖(override): 覆 盖指的是派生类的虚拟函数覆盖了基类的同名且参数相同的函数,既然是和虚拟函数挂钩,说明了这个是一个多态支持的特性,所谓的覆盖指的是用基类对象的指针 或者引用时访问虚拟函数的时候会根据实际的类型决定所调用的函数,因此此时派生类的成员函数可以"覆盖"掉基类的成员函数.注意唯有同名且参数相同还有带有virtual关键字并且分别在派生类和基类的函数才能构成虚拟函数,这个也是派生类的重要特征. 而且,由于是和多态挂钩的,所以只有在使用类对象指针或者引用的时候才能使用上. 总之一句话:覆盖函数都是虚函数,反之不然~~ (如果基类和继承类的函数名称,产生返回值都是一样的[如果返回值不同应该无法编译],如果基类用到了virtual,那么无论继承类的实现中是否加入virtual 这个keyword,还是会构成 override 的关系) 隐藏(hide): 指 的是派生类的成员函数隐藏了基类函数的成员函数.隐藏一词可以这么理解:在调用一个类的成员函数的时候,编译器会沿着类的继承链逐级的向上查找函数的定 义,如果找到了那么就停止查找了,所以如果一个派生类和一个基类都有同一个同名(暂且不论参数是否相同)的函数,而编译器最终选择了在派生类中的函数,那 么我们就说这个派生类的成员函数"隐藏"了基类的成员函数,也就是说它阻止了编译器继续向上查找函数的定义.... 回到隐藏的定义中,前面已经说了有virtual关键字并且分别位于派生类和基类的同名,同参数函数构成覆盖的关系,因此隐藏的关系只有如下的可能:1)必须分别位于派生类和基类中 2)必须同名 3)参数不同的时候本身已经不构成覆盖关系了,所以此时是否是virtual函数已经不重要了 当参数相同的时候就要看时候有virtual关键字了,有的话就是覆盖关系,没有的时候就是隐藏关系了很多人分辨不清隐藏和覆盖的区别,因为他们都是发生在基类和派生类之中的.但是它们之间最为重要的区别就是: 覆盖的函数是多态的,而隐藏的函数都是一般的函数,不支持多态,在编译阶段就已经确定下来了.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值