Why is there no operator +/- for a bidirectional iterator?

前端 未结 3 858
执笔经年
执笔经年 2021-01-25 11:35

My own reasoning for it is that there is no random access and there is no way to know the bounds. But then why do we have std::advance? [EDIT] And come to think of

3条回答
  •  长情又很酷
    2021-01-25 12:14

    You are right; the requirements for operator+/- is that it be an O(1) operation, which cannot be met by bidirectional iterators. std::advance has no such speed requirement (but will use it when available, e.g., for random access iterators).

    Note that boost has boost::next and boost::prior implementations for iterators; I'm not sure what their status is on standardization but if it's in boost it's solid.

提交回复
热议问题