继承中的同名函数变量以及继承中的构造与析构

 基类成员的作用域,伸到所有派生类

  派生类的重名成员屏蔽基类的重名成员(函数一样)

(如果一定要访问父类的b(类名::成员变量这样方式来访问)

#include<iostream>
/*
  基类成员的作用域,伸到所有派生类
  派生类的重名成员屏蔽基类的重名成员(函数一样
*/
class A
{
public:
	int a;
	int b;
	void printB()
	{
		std::cout << "我是父类的B " <<b<< std::endl;
	}
protected:
private:
};
class B :public A
{
public:
	int b;
	int c;
	void printB()
	{
		std::cout << "我是子类的B " << b << std::endl;
	}
};
void main()
{
	B b1;
	b1.b = 10;//访问子类的b(屏蔽了父类的b)
	b1.A::b = 11;//(如果一定要访问父类的b(类名::成员变量这样方式来访问)
	b1.printB();
	b1.A::printB();
	system("pause");
}





继承中的构造与析构

1.子类对象在创建时会首先调用父类的构造函数
2.父类构造函数执行结束后,执行子类的构造函数
3.当父类的构造函数有参数时,需要在子类的初始化列表中,显示调用

4.析构函数调用的先后顺序与构造函数相反

初始化列表(为了调用老爹的有参构造函数,使用初始化列表)

#include<iostream>

class Parent
{
public:
	Parent(char *p)
	{
		std::cout << "父类构造函数" << p<<std::endl;
	}

	void printP()
	{
		std::cout << "我是爹" << std::endl;
	}
protected:
	int a, b;
private:
};


class Child :public Parent
{
public:
	Child() :Parent("aaaaa")//初始化列表(为了调用老爹的有参构造函数,使用初始化列表)
	{
		a = b = c = 0;
		std::cout << "子类构造函数" << std::endl;
	}

	void printC()
	{
		std::cout << "我是儿子" << std::endl;
	}
protected:
private:
	int c;
};

void mai1111n()
{      //没有爹哪有儿子
	//Parent p1("ddddd");
	Child c1;

	system("pause");

}










  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值