如何将模板函数作为模板类参数传递
How to pass a template function as template class argument?
事情
是这样的,似乎可以传递一个包含一些静态函数的模板化结构,如下所示:
template <class T> struct FunctionHolder {};
template <> struct FunctionHolder<string> {
static void f(const string &s) {
cout << "f call " << s << endl;
}
};
template <class Key, class Value, class Holder = FunctionHolder<Key>>
class Foo {
public:
Foo(Key k) {
Holder::f(k);
}
};
int main(int argc, char *argv[]) {
Foo<string, int> foo = Foo<string, int>("test_string");
}
但是,是否可以直接传递模板化函数而无需在模板化结构上静态定义?我已经试过了,它不会编译:
template <class string> static void f(const string &s) {
cout << "f call " << k << endl;
}
template <class Key, class Value, typename func<Key>> class Foo {
public:
Foo(Key k) {
func(k);
}
};
int main(int argc, char *argv[]) {
Foo<string, int> foo = Foo<string, int>("test_string");
}
问这个 cos 被迫创建虚拟结构(包含一堆静态函数的结构(用作主类的模板类型并不酷。
不幸的是,
函数模板不能用作模板模板参数;您可以使用函数指针作为非类型模板参数,例如
template <class Key, class Value, void(*func)(const Key&) = f<Key>> class Foo {
public:
Foo(Key k) {
func(k);
}
};
住
相关文章:
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 使用指向成员的指针将成员函数作为参数传递
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- 修改函数中的指针(将另一个指针作为参数传递)
- 将成员函数指针作为参数传递给模板方法
- 如何在C++中将迭代器作为函数参数传递
- 将附加参数传递给使用 beast::bind_front_handler 调用的函数
- 如何将一个类的函数作为另一个类的另一个函数的参数传递
- 如何传递带有通过引用传递的结构参数的函数?
- 如何在 c++ 中将函数作为参数传递?
- 如何将成员函数作为回调参数传递给需要"typedef-ed"自由函数指针的函数?
- 将参数打包的参数传递到 std::queue 中,以便稍后使用不同的函数调用
- 为什么我不能将引用作为 std::async 的函数参数传递
- 如何在不使用指针的情况下将派生类的对象作为参数传递给基类中的函数?
- 将__device__ lambda 作为参数传递给 __global__ 函数
- 是否可以在不填充自己的参数的情况下将模板函数作为参数传递?
- 如何将成员函数作为参数传递并在派生对象上执行方法列表
- 将函数作为参数传递以避免重复代码
- 如何在类(C )中作为参数传递函数