问题场景
类的继承中,如果子类想使用父类的构造函数,则需要在子类的构造函数中声明使用父类的构造函数,例子如下:
struct A
{
A(int i){}
};
struct B:A
{
B(int i):A(i),d(i){}
int d;
};
但是如果父类中含有多种版本的构造函数,那么子类的构造函数需要多种版本的实现,实现起来很不方便。如下例子:
struct A
{
A(int i) {}
A(double d,int i){}
A(float f,int i,const char* c){}
};
struct B:A
{
B(int i):A(i){}
B(double d,int i):A(d,i){}
B(folat f,int i,const char* c):A(f,i,e){}
};
解决方法
通过使用using方式来解决这个问题。方式如下:
struct A
{
A(int i) {}
A(double d,int i){}
A(float f,int i,const char* c){}
};
struct B:A
{
using A::A;
};
int main()
{
B b(356);
}
这样会降低开发者的开发成本,使用起来更加的方便一些。
注意事项
- 对于继承构造函数来说,参数的默认值是不会被继承的,并且,默认值会导致基类产生多个构造函数版本号(即参数从后一直往前面减。直到包括无參构造函数,当然假设是默认复制构造函数也包括在内),这些函数版本号都会被派生类继承。
当派生类拥有多个基类时,多个基类中的部分构造函数可能导致派生类中的继承构造函数的函数名。例如:
struct A
{
A(int){}
};
struct B
{
B(int){}
};
struct C:A,B
{
using A::A;
using B::B;
};
上述代码中的A和B的构造函数会导致C中会重复定义相同类型的继承构造函数。
假设基类的构造函数被声明为私有构造函数或者派生类是从基类虚继承的,那么就不能在派生类中声明继承构造函数。
- 假设一旦使用了继承构造函数,编译器就不会为派生类生成默认构造函数。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)