2

我试图从作为模板参数传递给另一个类的类中获取静态方法的地址。下面是一个精简的例子:

#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 使用索引技巧等创建了一个数组。任何帮助将不胜感激。

4

1 回答 1

4

确实,该错误消息会引起一些头疼。以下是缺少的内容:

return &Function::template Func<N>;
//                ^^^^^^^^

Function是模板参数,您需要帮助编译器并告诉它嵌套名称Func命名模板。

于 2013-10-25T18:35:20.297 回答