0

我需要一个用于不同功能的开关来规避频繁的 if 方向。它应该类似于以下代码,封装在一个类中:

#include<iostream>
#include<stdlib.h>

using namespace std;

template<class T>
class MaxSwitch
{
public:
typedef T (MaxSwitch::*Max_P)(T,T);
Max_P fooC_P;

MaxSwitch(int Q) {
    if (Q==0)fooC_P=&MaxSwitch::MaxVal1;
    else fooC_P=&MaxSwitch::MaxVal2;
}

inline T MaxVal1(T kx,T MAX)
{
    return kx+1;
}

inline T MaxVal2(T kx,T MAX)
{
    return MAX;
}

};

 int main( int argc, char ** argv )
{
int Q=atoi ( argv[1] );
MaxSwitch<int> MAXSW(Q);


int MAX=5;

for ( int kx=0;kx<MAX;kx++ ) for ( int ky=0;ky<(MAXSW.fooC_P)(kx,MAX);ky++ )
    {
        cout<<"(kx="<<kx<<", ky="<<ky<<endl;
    }

return 0;
 }

我现在有一个小问题,即函数调用 (MAXSW.fooC_P)(ky,MAX) 是错误的。如何正确地做到这一点?

4

1 回答 1

6

MAXSW.fooC_P是您需要调用的指向成员函数的指针,并且MAXSW是您要调用它的对象。因此,您可以使用以下命令调用该函数:

(MAXSW.*(MAXSW.fooC_P))(ky,MAX);
于 2012-05-19T08:32:01.407 回答