目前我使用迭代器搜索一个向量并测试它的元素.我访问使用的元素
std::vector<int>::iterator it; if (*it == 0);
我可以使用相同的指针算术风格逻辑来测试下一个元素(不改变我的迭代器)?
我首先需要看看它是否会将迭代器推出界限
if (it != myvec.end())
然后测试当前元素和下一个元素
if (*it == 1 && *(it + 1) == 1)
这个工作是否像我期望的那样使用指针?
解决方法
是的,std :: vector的迭代器是
random access iterators,所以你加/减积分值来获得其他有效的迭代器.
从技术上来说,它可能不是指针算术,但它们就像指针一样.