我试图从作为模板参数传递给另一个类的类中获取静态方法的地址。下面是一个精简的例子:
#include <iostream>
#include <array>
using namespace std;
typedef size_t Data;
class MyFunction
{
private:
static const std::array<std::string, 3> values;
public:
template<size_t N>
static void Func(const Data& aData)
{
size_t index = (N > aData ? 2 : (N == aData ? 1 : 0) );
cout << "Function::Func<"<< N << ">:\t" << N << values[index] << aData << endl;
}
typedef decltype(&Func<0>) type;
};
const std::array<std::string, 3> MyFunction::values {"<", "=", ">"};
template<class Function, size_t N>
class FunctionManager
{
private:
static const typename Function::type func_;
static constexpr typename Function::type Create()
{
return &Function::Func<N>; //ERROR: Causes "overloaded function with no contextual information".
}
public:
void operator()(const Data &aData) const
{
func_(aData);
}
};
template<class Function, size_t N>
const typename Function::type FunctionManager<Function, N>::func_ = FunctionManager<Function, N>::Create();
int main()
{
static const size_t N = 6;
auto man = FunctionManager<MyFunction, N>();
man(N/2);
return 0;
}
您还可以在此处找到代码。问题出在 Create() 函数中,我收到“没有上下文类型信息的重载函数地址”错误。但是,如果我将 &Function::Func 更改为 &MyFunction::Func,它可以正常工作。我想让实际函数成为模板参数而不是硬编码,有人知道如何解决这个问题吗?请注意,我意识到有更简单的方法可以做我想做的事情,但是实际代码而不是单个 Function::type 使用索引技巧等创建了一个数组。任何帮助将不胜感激。