限制可以传递给C++中另一个函数的函数

Restricting functions that can be passed to another function in C++

本文关键字:函数 C++ 另一个      更新时间:2023-10-16

我有一个类,包含几个非常相似的函数和一些其他函数,它们将这些可互换的函数作为输入。

一个更简单的例子:

class functions{
      public:
           int a();
           int b();
           int F(int (*f)() ); //f can only be a() or b()
};

在我把它们放进课堂之前,我有一些类似的东西

if(f!=a || f!=b) cout<<"error";

对于这个类,它似乎变得更加复杂,因为我认为我现在需要传递一个类实例或其他东西来摆脱我的error: invalid use of member function

我刚刚开始学习枚举列表,如果我处理的是正常变量,这似乎就可以了。我可以创建函数的枚举吗?

限制可以传递给另一个函数的函数的最佳方式是什么?


我正在追求静态强制转换方法,但仍然需要int F(int(*F)())的帮助;

int functions::F(int (functions::*f)() )
{
    if(f==functions::a)  
        //gives  error: invalid operands of types 'int (functions::*)()' 
           //  and 'int (int(*)()' to binary operator =='
    int x=f();
        //gives error: must use ‘.*’ or ‘->*’ to call pointer-to-member
          //function in  'f(...)' 
    int y=(functions.*f)();
         //gives error: expected primary-expression before ‘.*’ token
     return 0;
}

这实际上取决于您想要实现的目标:我想说的是,这种限制最好通过代码审查而不是编码来验证。。。

另一种解决方案是完全不使用该构造,并生成一个Fa()Fb()函数,调用(私有)a()b()成员函数。

问题的其余部分是"我如何调用类的成员函数"——答案在很大程度上取决于Functions是否具有在a()b()中使用的成员变量。如果没有成员函数,则将a()b()成员声明为static即可。另一方面,如果要使用"成员函数指针",语法分别为int (Functions::*f)&Functions::a,并且必须使用Functions的实例进行调用。所以如果我们有Functions fun,你就做fun.*f()。或(*this).*f(),参见F()

您可以将接受的函数包装在一个类中:

#include <iostream>
class Functions
{
    public:
    int a() { return 0; }
    int b() { return 1; }
};
class Accept
{
    public:
    typedef int (Functions::*AcceptFunction)();
    int apply(Functions& object,  AcceptFunction function) {
        return (object.*function)();
    }
};

int main()
{
    Functions functions;
    Accept accept;
    std::cout << accept.apply(functions, &Functions::b) << std::endl;
}

(可以通过在Accept中将Functions作为嵌套类进行捆绑)