我有一个函数对象向量(std::function
),它们都来自一个公共基类base
,如下所示。迭代向量时,我希望访问并可能更改目标中的变量 - 例如test
。在编译时,std::function::target()
可以返回指向原始目标的指针,但有没有办法在运行时执行此操作 - 即动态访问test
?仿函数向量可以由任意数量的不同目标函数组成。 Boost不是此代码库的选项。
#include <iostream>
#include <functional>
#include <vector>
typedef std::function<double(double)> Tfunc;
struct base { bool test; };
struct half : public base {
template<typename T> T operator()(T x) { return x*0.5; }
};
struct square : public base {
template<typename T> T operator()(T x) { return x*x; }
};
int main() {
std::vector<Tfunc> v;
v.push_back( half() );
v.push_back( square() );
v[0].target<half>()->test=false;
v[1].target<square>()->test=true;
for (auto &f : v)
std::cout << f(2.0) << " " << f.target_type().name() << "\n";
return 0;
}
输出:
1 4half
4 6square
答案 0 :(得分:0)
你真的需要使用继承将测试变量放在仿函数中吗?您可以像这样编写仿函数和测试变量:
struct math_operation
{
Tfunc f;
bool test;
};
std::vector<math_operation> v;
v.push_back( math_operation() );
v.push_back( math_operation() );
v[0].f = half();
v[1].f = square();
v[0].test = false;
v[1].test = true;