#include<vector>#include<algorithm>int main(voID){ std::vector<double> a,b; for(auto& ab:{a,b}) std::sort(ab.begin(),ab.end()); // error }
此代码失败,因为auto&是一个const引用.周围有优雅的方式吗?
解决方法 我认为问题在于它有点像将临时绑定绑定到非const引用.那里没有“具体”的集合,所以有点像临时的.如果你有一个临时向量,它将绑定到const引用,但不是非const引用.
我也认为这不会对你正在做的事情起作用,但这应该有效:
#include<vector> #include<algorithm> int main(voID){ std::vector<double> a,b; for(std::vector<double>* ab:{&a,&b}) std::sort(ab->begin(),ab->end()); // or begin(*ab),end(*ab)}
和汽车也可以工作.
总结以上是内存溢出为你收集整理的c – 对引用的迭代?全部内容,希望文章能够帮你解决c – 对引用的迭代?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)