C++继承具有不同默认参数值的函数
C++ inherit a function with different default argument values
我想继承一个成员函数而不重新定义它,但给它不同的默认值。我该怎么办?
class Base{
public:
void foo(int val){value=val;};
protected:
int value;
};
class Derived : public Base{
public:
void foo(int val=10);
};
class Derived2 : public Base{
public:
void foo(int val=20);
};
void main(){
Derived a;
a.foo();//set the value field of a to 10
Derived2 b;
b.foo();//set the value field of b to 20
}
不要使用默认值,使用重载:
class Base{
public:
virtual void foo() = 0;
protected:
void foo(int val) { value = val; }
private:
int value;
};
class Derived : public Base {
public:
void foo() override { Base::foo(10); }
};
class Derived2 : public Base {
public:
void foo() override { Base::foo(20); }
};
override
修饰符为 C++11。
不,你不能。但是你可以像这样实现它。
class Base{
public:
virtual int getDefaultValue() = 0;
void foo(){value = getDefaultValue();};
protected:
int value;
};
class Derived : public Base{
public:
int getDefaultValue() {
return 10;
}
};
class Derived2 : public Base{
public:
int getDefaultValue() {
return 20;
}
};
在斯科特·迈耶斯(Scott Meyers)的"有效C++"中,有一章叫做"永远不要重新定义函数的继承默认参数值"。你真的不应该。你可以阅读关于如果你这样做将会发生的所有恐怖的非常令人信服的解释的章节。
你必须重新定义它——没有其他方法可以指定不同的默认参数。但是你可以通过调用基本版本来保持实现的微不足道:
class Base{
public:
void foo(int val){value=val;};
protected:
int value;
};
class Derived : public Base{
public:
void foo(int val=10) { Base::foo(val); }
};
class Derived2 : public Base{
public:
void foo(int val=20) { Base::foo(val); }
};
相关文章:
- 将可变参数函数的参数封装在类实例中
- QML 使用带有参数C++函数
- 使用可变参数函数作为模板参数
- 如何在C++中伪造虚拟可变参数函数模板?
- 为什么可变参数函数不适用于模板
- C++ std::functional 中的可变参数函数模板
- 可变参数函数指针的定义对于VxWorks spyLib来说不清楚
- 使用可变参数函数覆盖具有不同函数签名的虚函数
- 考虑引用和常量的可变参数函数包装器
- 使用可变参数函数将整数和/或整数数组放入单个 int 数组中
- 在可变参数函数中转发特定范围的参数
- 通过引用传递参数;函数返回类型是否必须为 VOID?
- 使用带有一个参数函数的递归找到数字的平方
- 可变参数函数模板不能很好地使用 std::function 作为参数
- 多个可变参数函数的单个模板参数包?
- 参数数据类型未知的可变参数函数
- 可变参数函数参数包扩展
- 使用模板可变参数函数将多个参数传递给另一个函数
- 对可变参数函数的递归调用的链接器错误
- 通过像printf这样的可变参数函数传递一个带有常量字符*转换函数的类