继承中同名函数的处理和static的处理方法

本文探讨了在面向对象编程中,子类与父类同名成员变量的处理方法,包括如何通过作用域分辨符区分同名成员,以及静态成员在类继承体系中的访问特性。通过具体代码演示了子类如何正确访问父类的同名静态成员。
同名函数的处理方法

1、当子类成员变量与父类成员变量同名时,子类依然从父类继承同名成员
2、在子类中通过作用域分辨符::进行同名成员区分(在派生类中使用基类的同名成员,显式地使用类名限定符)
3、同名成员存储在内存中的不同位置

如果没有说明的情况,默认会使用子类的同名函数或者变量

static的情况
  1. 基类定义的静态成员,将被所有派生类共享
  2. 根据静态成员自身的访问特性和派生类的继承方式,在类层次体系中具有不同的访问性质 (遵守派生类的访问控制)
  3. 派生类中访问静态成员,用以下形式显式说明:
    类名 :: 成员


static易犯错误(不但要初始化,更重要的显示的告诉编译器分配内存)
下面是代码演示

class AA
{
	public:
		int a;
		int b;
		static int c;
	public: AA (int a=0,int b=0)
			{
				this->a=a;
				this->b=b;
				cout<<"AA running"<<endl;
			}
			~AA ()
			{
				cout<<"AA end"<<endl;
			}
};
int AA::c=10; //必须要显性的分配内存!!!!!!
class BB : public AA
{
	public:
		int c;
		int b;
	public: BB (int a=0,int va=10)
			{
				b=va; //初始化类BB中为10
				AA::c++; //使用::通配符来访问static
				cout<<"BB running"<<endl;
			}
			~BB ()
			{
				cout<<"BB end"<<endl;
			}
			void prt()
			{
				cout<<"a="<<a<<" b="<<AA::b<<" c="<<AA::c<<endl;
				//这里打印的是类AA的b,同时还有AA中static中的c
			}

};
int main(int argc, char *argv[])
{
	BB a(3);
		a.prt();
	return 0;
}

在这里插入图片描述
得到结果,符合我们的结论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值