【发布时间】:2014-12-10 03:11:28
【问题描述】:
我想要一个指向函数的函数指针,该函数将带有模板参数的类作为参数(请参阅main)。我相信我接近正确的语法,但我收到编译错误:“模板声明不能出现在块范围内”。
#include <iostream>
#include <array>
template<int N>
class NumberHolder
{
public:
NumberHolder();
int x_;
};
template<int N>
NumberHolder<N>::NumberHolder() : x_(N) {}
template<int N, int M>
void add(NumberHolder<N>& nh)
{
nh.x_ += M;
}
template<int N, int M>
void mult(NumberHolder<N>& nh)
{
nh.x_ *= M;
}
int main()
{
NumberHolder<3> nh;
//using f_ptr = void(*)(NumberHolder<3>&); // Compiles
template<int N> using f_ptr = void(*)(NumberHolder<N>&); // Doesn't compile
std::array<f_ptr, 2> operations;
operations[0] = &add<3, 41>;
operations[1] = &mult<3, 8>;
for (int i = 0; i < operations.size(); ++i)
{
operations[i](nh);
}
std::cout << nh.x_ << std::endl;
return 0;
}
【问题讨论】:
-
您只能通过使用 C++14 的 变量模板 来接近它。但是这些和所有模板一样,不能在本地声明。
-
无论如何,您不能将类模板用作类,也不能将变量模板用作变量。用 Stephan T. Lavavej 的话来说:“你不能吃饼干刀。”
std::array<f_ptr, 2>因此不能合法:f_ptr是一个模板,std::array需要一个类型作为它的第一个模板参数。
标签: c++ function templates pointers function-pointers