首页 > 后端开发 > C++ > 为什么 C 中的初始化列表模板推导失败?

为什么 C 中的初始化列表模板推导失败?

Mary-Kate Olsen
发布: 2024-11-29 16:39:09
原创
709 人浏览过

Why Does Template Deduction Fail with Initializer Lists in C  ?

模板推导和初始化列表

考虑以下函数:

template<typename T>
void printme(T&& t) {
  for (auto i : t)
    std::cout << i;
}
登录后复制

此函数采用带有 begin()/end 的单个参数() 启用类型。但是,以下代码片段被认为是非法的:

printme({'a', 'b', 'c'});
登录后复制

尽管使用向量、字符串、数组和显式初始化列表的类似代码可以正常工作。问题来了,为什么这个特定的片段是非法的?

理解这个问题的关键在于模板参数推导。在这种情况下,无法推导模板参数 T。为了纠正这个问题,必须显式指定模板参数,如下所示:

printme<vector<char>>({'a', 'b', 'c'})
printme<initializer_list<char>>({'a', 'b', 'c'})
登录后复制

在上述代码合法的片段中,参数拥有明确定义的类型,允许使用模板参数 T可以无缝推断。使用 auto 还可以使函数正常工作,因为它推断类型为 std::initializer_list

但是,在比较模板参数推导和 auto 关键字时,会出现奇怪的行为。虽然 auto 将类型推断为 std::initializer_list,但模板参数推导却不然。这是因为 C 11 标准明确指出,当函数参数是初始值设定项列表,但参数没有 std::initializer_list 或对可能 cv 限定的 std 的引用时,这是模板参数的非推导上下文::initializer_list 类型。

尽管如此,auto 关键字特别支持 std::initializer_list,允许代码运行正确。

以上是为什么 C 中的初始化列表模板推导失败?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板