未知类型的c++模板参数
C++ template argument of unknown type
假设我们想要编写一个函数,该函数应该获得一个值作为模板参数(例如,出于效率原因),但我们事先不知道我们期望的参数类型。可以将其实现为
template<typename T, T val>
func() { cout << val; }
然而,调用这样的函数并不有趣
func<int, 5>()
是否可以重写函数s.t.,我们可以用下面的方式调用它?
func<5>()
一个主要取决于实际功能的解决方案是如下定义:
template<typename T>
constexpr void func(T val) { }
然后将其作为f(5)
调用,并从函数本身的参数推导出模板参数。
否则,在c++ 14中,不能避免使用模式template<typename T, T value>
。它与标准模板库使用的模式相同,参见std::integral_constant
的定义示例。
template<typename T>
struct S {
template<T value>
static void func() {}
};
你可以这样做:
using IntS = S<int>;
// ....
IntS::func<5>();
在即将发布的c++ 17版本中,您将按照如下方式进行操作:
template<auto value>
void func() {}
这可以作为f<5>()
调用,这就是您正在寻找的…
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用