2

我正在尝试创建一个接收函数、调用它并将其返回的函数。我已经尝试了几件事,包括很多模板组合,但似乎都没有。这样做的正确方法是什么?

4

4 回答 4

9
template <typename Functor>
Functor your_function(Functor toCall)
{
    toCall();
    return toCall;
}

如果你想返回函子返回的东西,那么你会使用类似的东西:

// Requires C++11
#include <type_traits>

template <typename Functor>
typename std::result_of<Functor()>::type your_function(Functor toCall)
{
    return toCall();
}

另请注意,这在 C++14 中会变得更容易decltype(auto)

//Requires C++14    
template <typename Functor>
decltype(auto) your_function(Functor toCall)
{
    return toCall();
}
于 2013-09-05T05:30:10.247 回答
5

一个函数不能接收另一个函数作为参数——C 不允许,C++ 也不允许。

但是,您可以将指向函数的指针作为参数传递,然后通过该指针调用该函数。

#include <iostream>

int f() { std::cout << "called f\n"; return 2; }

typedef int (*ptr)();

int g(ptr p) { return p(); }

int main(){
    std::cout << g(f);
}

结果:

called f
2

如果您愿意使用函数模板而不是函数,则可以将函数的名称作为模板参数传递并调用它。在大多数情况下,最好使用仿函数(重载的类的实例,operator()因此可以像函数一样调用它)而不是函数。

于 2013-09-05T05:38:54.550 回答
2

算法:

  1. 使函数接收一个参数,该参数是一个函数指针。
  2. 使用函数指针调用函数。
  3. 返回函数指针。函数不是 C 和 C++ 中的一等对象。因此,您将需要使用指向函数的指针。
于 2013-09-05T05:31:21.213 回答
0

下面是一个函数的语法,该函数将函数指针作为其参数之一传递:

int Func (int (*funcToCall) (int, int)) /* This is how to receive the function as a parameter */
{
    int val = funcToCall (1, 2); /* This is how to call the function once it's received as a parameter */
    return (val);
}
int FuncToBePassed (int x, int y) /* This is a sample function that fits the format we need to pass into Func */
{
    return (x+y);
}
printf ("%d\n", Func (FuncToBePassed)); /* This is how to pass the function reference to the first function */

所以,在这个例子中,我们有一个带有两个 int 参数的函数 (FuncToBePassed),然后是一个函数 (Func),它希望传递一个像 FuncToBePassed 这样的函数。最后,最后一行代码就是这样做的,调用 Func 并将对 FuncToBePassed 的引用传递给它。

顺便说一句,如果您不完全致力于使用 C++,我强烈建议您改用 C#,因为像传递函数这样的细节设计得更好。因此,如果您打算花时间掌握一门语言,请选择更实用的语言。除非您要维护一些已经在 C++ 中的代码,这是可以理解的……希望我回答了您的问题!

于 2013-09-05T05:36:28.060 回答