在没有lambdas的情况下将模板化函数作为方法参数传递?

我确实希望能够使用extFunction或std::maxstd::min作为Square方法的参数,而无需声明lambda:

template<typename T>
T extFunction(T a, T b)
{
    return a;
}

class Stuff
{
public:
    template <typename F>
    int square(int num, int num2, F&& func) 
    {
        return func(num, num2);
    }
};

int main()
{
    Stuff s;
    std::cout << s.square(1, 2, std::max<int>) << std::endl;
    return 0;
}

但编译器(GCC 11.1)告诉我:

该函数不明确:";无法推导模板参数‘F

没有lambdas有什么简单的方法可以做到这一点吗?

编辑:

演示如何使用lambdas执行此操作可能会很有趣:

std::cout << s.square(1,2,[](auto&& a, auto&& b){return std::max(a,b);}) << std::endl;
    
std::cout << s.square(1,2,[](auto&& a, auto&& b){return std::min(a,b);}) << std::endl;
    
std::cout << s.square(1,2,[](auto&& a, auto&& b){return extFunction(a,b);}) << std::endl;

输出:

Program returned: 0
Program stdout

2
1
1

解决方案

您不应使用标准库函数的地址。请查看此处的详细信息:

Can I take the address of a function defined in standard library?

因此,除了将std::max打包到函数对象(即lambda、unctor)或函数中之外,没有其他简单的方法。

相关文章