理解模板参数推导
Understanding template argument deduction
本文关键字:参数 更新时间:2023-10-16
考虑以下代码:
#include <vector>
template <typename T>
using v_itt = typename std::vector<T>::iterator;
template <typename T>
void foo(v_itt<T>){ }
int main() {
typename std::vector<long>::iterator i = std::vector<long>().begin();
foo(i); //candidate template ignored: couldn't infer template argument 'T'
}
演示
代码出了什么问题?我认为T
应该被推导出long
。有没有办法以某种方式解决这个问题?
typename std::vector<T>::iterator
iterator
(依赖类型)它在代码中是不可推导的,因为它在嵌套的名称说明符中,并且标准规定
§14.8.2.5/4
然而,在某些上下文中,该值不参与类型推导,而是使用在其他地方推导或明确指定的模板参数的值如果模板参数仅在非推导上下文中使用,并且未明确指定,则模板参数推导失败
和§14.8.2.5/5
未推导的上下文为:
--使用限定id指定的类型的嵌套名称说明符。
所以这是一个非推导的上下文。
可能的解决方案:
- 传递向量引用而不是迭代器
- 使用标记调度和编译时断言来验证迭代器
我只想为Marco的答案添加一个可能的解决方法3:
#include <vector>
template<typename T>
void real_foo( typename std::vector<T>::iterator){}
template <typename T>
void foo(T i){ real_foo<typename decltype(i)::value_type>(i); }
int main() {
std::vector<long> v;
foo(v.begin());
}
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用