使用构造函数进行类模板参数推理
Class template parameter inference with constructor
我有以下模板类:
template <typename T>
struct timer
{
T period;
timer(T p) :
period(p)
{}
};
要实例化它,我需要做:
timer<double> t(double(0.0));
可以改进timer
的类定义以允许以下语法:
timer t(double(0.0));
并让编译器从构造函数的参数推断double
类型?
不,你不能那样做。在这些情况下不会发生类型推断。不过,您可以使用 auto
关键字和函数模板来简化操作:
template<typename T>
timer<T> make_timer(T value) {
return value;
}
// let the compiler deduce double
auto t = make_timer(0.0);
请注意,auto
关键字的这种使用仅在 C++11 标准中有效。
此外,对于这种特定情况,您可以typedef
一个double
计时器:
typedef timer<double> timer_d;
timer_d t(0.0);
虽然我仍然会选择第一个解决方案,但如果您可以使用 C++11。
不,这是不可能的,演绎只适用于函数。通常的解决方案是编写一个返回新实例的 make_
函数。这是C++11:
template <typename T>
timer<T> make_timer(T&& p) {
return timer<T>(std::forward<T>(p));
}
auto t = make_timer(0.0);
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 关于模板参数推理的看似有缺陷的段落?
- 从函数指针对标准 C++98 中的函数类型参数进行静态推理
- C++模板参数推理
- 使用构造函数进行类模板参数推理
- 为什么此模板参数推理失败