派生类与基类均使用动态内存时构造函数问题&如何使用基类友元函数

1、基类使用new,派生类不使用new

当派生类没有自己的动态内存时,不需要显示定义复制构造函数、赋值运算符、析构函数。因为编译器自动调用。
在派生类默认复制构造函数中:完成派生类成员复制,然后调用我们在基类中显式声明的复制构造函数,完成基类成员的复制。
赋值运算符类似。

2、基类使用new,派生类使用new

需要显示定义复制构造函数、赋值运算符、析构函数。因为解决浅拷贝问题,完成派生类动态空间的开辟
其中复制构造函数通过初始化列表调用基类复制构造函数
赋值运算符在函数内通过作用域运算符调用赋值运算符。例子:

Child& Child::Child(const Child& a):Base(a){ // 调用基类复制构造函数,完成基类部分复制
											 // 此处Base(a),基类引用指向派生类对象
	... //处理派生类的自己的成员
}
Child& Child::operator=(const Child& a){
	if(this == &a )
		return *this;  //防止自己赋值给自己
	Base::operator=(a) // 作用域解析运算符调用基类方法,完成基类赋值
	... //完成派生类成员赋值
}

3、如何访问基类友元函数。

首先友元函数不是类成员函数,不能继承,同时也不能利用作用域解析运算符调用基类友元函数
派生类对象调用基类友元函数,需要将对象类型强制转换,以匹配基类参数列表
例:

std::ostream& operator<<(std::ostrean& io, const Child& a){
	io<<(const Base&) a; //转换类型以匹配基类函数参数列表如下:
	// std::ostream& operator<<(std::ostrean& io, const Base& a)
	... //此处再处理派生类的内容
}

参考资料:C++ Primer Plus 13.7节

总结:

1、派生类使用new需要显示定义复制构造函数、赋值运算符、析构函数。因为解决浅拷贝问题,完成派生类动态空间的开辟
2、访问基类友元函数:通过对象类型强制转换,以匹配基类友元函数参数列表
3、复制/赋值对象时,应确保对象内所有成员变量以及所有基类成员变量都完成拷贝,即不要忘记派生类调用基类构造函数。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值