使用基类的重载函数
using overloaded function of the base class
我试着这样做
class base {
public:
virtual double operator() (double val) = 0;
virtual double operator() (double prev, double val) {
return prev + operator()(val);
}
};
class derived: public base {
virtual double operator() (double val) {
return someting_clever;
}
};
我想重载操作符(),以便在std::accumulate或std::transform等不同的算法中使用它。我对operator()(double, double)的基类定义非常满意。然而,我不能从派生类调用它。我是否必须为从base派生的每个类重写相同的代码?
这里的问题是,在派生类中定义函数隐藏了基类中相同的函数;这就是为什么不能从派生类访问operator()(double, double)
的原因。
但是有一种方法可以做到这一点:您可以在派生类中使用using
指令:
class derived: public base {
using base::operator();
virtual double operator() (double val) {
return someting_clever;
}
};
你试过using指令吗?
class derived: public base {
virtual double operator() (double val) {
return someting_clever;
}
using base::operator();
};
相关文章:
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 可以打印矢量和矢量中的矢量的非重载C++函数
- 错误 没有与参数列表匹配的重载函数"getline"实例
- 使用模板重载函数
- C++线程中,没有重载函数接受 X 参数
- std::vector 没有重载函数的实例与参数列表匹配
- C++重载函数,一个采用基类的参数,另一个采用派生类的参数
- 错误:无法解析对重载函数的引用;你的意思是调用它吗?
- 对重载函数find_first_not_of的不明确调用
- 如何从重载解析中删除重载函数?
- CUDA:重载函数"isnan"的多个实例
- C++派生类重载函数(带有 std::function 参数)不可见
- 避免在人为的重载函数调用中拼写出类型
- C++:如何为多个重载函数保留通用代码路径?
- 什么时候可以使用常量装饰调用我的重载函数?
- 尝试使用谓词函数会导致错误:"std::sort"未找到匹配的重载函数
- std::调用,未找到匹配的重载函数
- 为什么在传递长整型时调用具有两个双精度类型的参数的重载函数?
- 为什么使用不匹配的参数调用重载函数仍然有效
- 如何通过签名作为模板参数来解决重载函数?