c – end()迭代器上的指针算法

前端之家收集整理的这篇文章主要介绍了c – end()迭代器上的指针算法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
设A是std :: vector< double>,

这个定义明确吗?

  1. if(!A.empty())
  2. std::vector<double>::iterator myBack = A.end() - 1;

结束迭代器是否仅适用于均等和不等式检查?或者只要我留在容器中,我就可以执行一些指针运算?

在我的平台上,此代码有效.我想知道这是否便携.

解决方法

它完全有效,因为vector :: iterator是一个随机访问迭代器.您可以对它执行算术运算,它不依赖于平台.
  1. std::vector<double>::iterator it = A.end();
  2. while (it != A.begin()){
  3. --it; //this will skip A.end() and loop will break after processing A.front()
  4. //do something with 'it'
  5. }

但A.end()指的是理论上的过去元素,因此它不指向一个元素,因此不应被解除引用.因此,最佳实践是使用反向迭代器而不是递减结束迭代器.

  1. for(std::vector<double>::reverse_iterator it = A.rbegin(); it != A.rend(); ++it) {
  2. //do something with 'it'
  3. }

这两个循环做同样的事情,第二个是可以理解的,更清洁的方式.

猜你在找的C&C++相关文章