如何将boost::bind对象存储为成员变量

How to store boost::bind object as member variable?

本文关键字:存储 成员 变量 对象 bind boost      更新时间:2023-10-16

我使用boost::bind动态创建组合函数,并希望将对象存储为某个类成员变量以供以后使用。例如,我们有两个函子:

struct add{double operator()(double x, double y) const{return x+y;};};  
struct multiply{double operator()(double x, double y) const{return x*y;};};  
然后创建一个函数f(x,y,z) = (x+y)*z,我可以这样做:
auto f = boost::bind<double>(multiply(), boost::bind<double>(add(), _1, _2), _3);

调用f(x,y,z)效果很好。现在我想将f保存为类成员变量,如下所示:

struct F  
{  
  auto func;  
  double operator(const std::vector<double>& args) const  
  {  
    return func(args[0],args[1],args[2]); //Skipping boundary check  
  }  
}
F f_obj;  
f_obj.func = f;  
f_obj(args);  

当然,我不能声明一个自动变量。有什么办法可以绕过这个吗?

注意,我没有使用boost::函数,因为它会极大地影响性能,这对我来说很重要。

谢谢你的建议

两种选择:使用boost::function,并测量它是否实际影响性能。

或者将F设为以func的类型为参数的模板,由bind表达式的类型推导出F。

编辑:第二个选项的问题是它没有摆脱尴尬的类型。你可以用模板覆盖的纯虚函数定义一个基类。但是,您需要管理动态内存并支付虚拟函数的成本-因此,您不妨回到boost::function(或std::function),它为您做了大致相同的事情。

bind()返回的类型是特定于函数对象和参数的每种组合的。如果要存储结果,则需要以某种方式擦除类型。最明显的方法是使用function<..> .

当结果函数对象被频繁调用时,function<...>有效地执行虚拟分派所带来的开销可能太高。解决这个问题的一种方法是将函数对象与合适的批量操作捆绑在一起,而不是存储函数对象来存储合适的应用程序。当需要单个呼叫时,这将不起作用,但是当需要大量呼叫时,虚拟调度只需支付一次。