将函数名称发送给函数

Set*_*nre 6 c++ pointers arguments function

我想做的是:

class A
{
    public:
    double sum(double a, double b);
    double max(double a, double b);
}

template <typename T>
class B
{
    std::vector<T> data;

    public:

    double sum (double a, double b);
    double max (double a, double b);
    double average( MyFunction, double a, dobule b)
    {
        double sum = 0;
        int n = data.size();

        for ( int i = 0; i < n; i++)
            sum = sum + data[i].MyFunction(double a, double b)

            return sum / n;
    }

}
Run Code Online (Sandbox Code Playgroud)

例:

double average( max, double a, double b)
{
    double sum = 0;
    int n = data.size();

    for ( int i = 0; i < n; i++)
        sum = sum + data[i].max(double a, double b)

        return sum / n;
}
Run Code Online (Sandbox Code Playgroud)

为什么?

  1. 它会省去我写的功能:总和的平均值.平均最大值 min的平均值都是非常相似的函数.
  2. 它的编码方式B< B< A> >有效

我试过了什么?

  • 功能指针
  • S1:

      typedef double (A::*MyFunctionf)(double, double);
      typedef double (B<A>::*MyFunctionff)(double, double);
      typedef double (B<B<A> >::*MyFunctionfff)(double, double);
    
    Run Code Online (Sandbox Code Playgroud)
    • 有用.问题:
      • 声明3-4 typedef函数指针并不美观
      • 如果我想在B内写出发送函数指针的函数,它将被硬编码,并且只有3个typedef中的1个可以被硬编码.含义:它并不适用于所有情况
  • S2(基于模板typedef - 你的工作是什么?):

      template <typename rtype, typename t>
      struct CallTemplate
      {
        typedef rtype (t::*ptr)(double, double);
      };
    
     // the function becomes :
     template <typename T>
     template<typename rtype>
     double B<T>::average(CallTemplate<double, T> MyFunction, double a, double b)
     {
        double sum = 0;
       int n = data.size();
    
          for ( int i = 0; i < n; i++)
            sum = sum + (data[i].*MyFunction)( a, b)
    
        return sum / n;
      }
    
    Run Code Online (Sandbox Code Playgroud)

    例:

     // makes an error "Myfunction was not declared" + " 
     // dependent-name'{anonymous}::CallTemplate<double, A>::ptr' 
     // is parsed as a non-type, but instantiation yields a type"
     CallTemplate<double, A>::ptr MyFunction = &A::max; 
     Average(max, t, v);
    
    Run Code Online (Sandbox Code Playgroud)

我不知道问题出在哪里.我也试过Boost.Function

650*_*502 2

是的,这是可能的。

您正在寻找成员指针。然而语法并不明显:

struct A
{
    double x, y;
    A(double x, double y) : x(x), y(y) {}
    double sum() { return x + y; }
    double max() { return std::max(x, y); }
};
Run Code Online (Sandbox Code Playgroud)

这是一个定义了几个方法(summax)的类。

template <typename T>
struct B
{
    std::vector<T> data;
    double average(double (T::*MyMethod)())
    {
        double sum = 0;
        int n = data.size();
        for (int i = 0; i < n; i++)
            sum = sum + (data[i].*MyMethod)();
        return sum / n;
    }
};
Run Code Online (Sandbox Code Playgroud)

这是一个类,其方法接受方法指针,并将计算对向量元素调用指向的方法的结果的平均值。

传递这两个方法的示例A是:

int main(int argc, const char *argv[]) {
    B<A> b;
    b.data.push_back(A(1, 2));
    b.data.push_back(A(3, 4));
    b.data.push_back(A(5, 6));
    std::cout << b.average(&A::max) << std::endl;
    std::cout << b.average(&A::sum) << std::endl;
    return 0;
}
Run Code Online (Sandbox Code Playgroud)