c – 我可以在STL :: vector :: iterator上执行指针算术

目前我使用迭代器搜索一个向量并测试它的元素.我访问使用的元素

std::vector<int>::iterator it;
if (*it == 0);

我可以使用相同的指针算术风格逻辑来测试下一个元素(不改变我的迭代器)?

我首先需要看看它是否会将迭代器推出界限

if (it != myvec.end())

然后测试当前元素和下一个元素

if (*it == 1 && *(it + 1) == 1)

这个工作是否像我期望的那样使用指针?

最佳答案
是的,std :: vector的迭代器是random access iterators,所以你加/减积分值来获得其他有效的迭代器.

从技术上来说,它可能不是指针算术,但它们就像指针一样.

转载注明原文:c – 我可以在STL :: vector :: iterator上执行指针算术 - 代码日志