我定义了名为CallBackAtInit
的类模板,其唯一目的是在初始化(构造函数)中调用函数。该函数在模板参数中指定。问题是模板不接受std::function
作为参数;但他们接受函数指针。为什么呢?
这是我的代码:
#include <iostream>
#include <functional>
/* Does not work:*/ template <typename return_type, typename arg_type, std::function<return_type(arg_type)> call_back>
/* Work fine: */// template <typename return_type, typename arg_type, return_type(*call_back)(arg_type)>
class CallBackAtInit {
public:
CallBackAtInit(arg_type arg)
{
call_back(arg);
};
};
void printInt(int i);
class HoldInt : private CallBackAtInit<void, int, printInt> {
public:
HoldInt(int integer)
: CallBackAtInit(integer)
{}
// ...
};
int main(int argc, char** argv)
{
HoldInt hi(10);
return 0;
}
void printInt(int i)
{
std::cout << i << std::endl;
}
答案 0 :(得分:10)
模板定义的参数可以有四种:
std::nullptr_t
(自C ++ 11起)当您在模板定义中提及std::function
时,它既不属于上述类别。模板不能接受类型,也不能接受整数值或指向成员值。
当参数是函数指针类型时,它可以接受函数指针(与该类型匹配的函数的地址),它只是一个整数值。请注意,地址始终是一个整数值。所以它属于第二类,这就是它起作用的原因。
答案 1 :(得分:2)
因为标准不允许这样做:
14.1模板参数
4非类型模板参数应具有以下之一 (可选择cv-qualified)类型:
- 整数或枚举类型,
- 指向对象或指向函数的指针,
- 对对象的左值引用或对函数的左值引用,
- 指向成员的指针,
- std :: nullptr_t。