c – 基于范围的超对列表

c – 基于范围的超对列表,第1张

概述说,我想迭代一些内联定义的对.是否有更短的写作方式: for(auto pair : std::initializer_list<std::pair<int,int>>{{1,2}, {3,4}}) // ... ? 只需指定第一个元素就是一对.其余的将自动推断: for(auto& pair : {std::pair<int,int>{1,2}, {3,4}}) ; 支撑的封闭初始化 说,我想迭代一些内联定义的对.是否有更短的写作方式:
for(auto pair : std::initializer_List<std::pair<int,int>>{{1,2},{3,4}})    // ...

解决方法 只需指定第一个元素就是一对.其余的将自动推断:
for(auto& pair : {std::pair<int,int>{1,4}})  ;

支撑的封闭初始化器被推导为std :: initalizer_List,并且第一个被命名为一对的元素将要求所有元素成为一对的初始化器.

你标记了C 11,但为了完整性,它可以在C 17中更短:

for(auto& pair : {std::pair{1,4}})  ;

由于类模板参数推断.如果你没有这个,那么如果你想保持模板参数扣除的好处,那么std :: make_pair会这样做:

for(auto& pair : {std::make_pair(1,2),4}})  ;

虽然表面上看,它不像C 17版本那样对代码打高尔夫球有用.

总结

以上是内存溢出为你收集整理的c – 基于范围的超对列表全部内容,希望文章能够帮你解决c – 基于范围的超对列表所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1242594.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存