小编mar*_*cbf的帖子

计算两个迭代器之间的距离时,"向量迭代器不兼容"

我遇到了一个我无法找到原因的问题.

在我的代码中的某个点上,我返回两个std :: vector迭代器之间的距离,一个是对向量的插入操作的结果,另一个是向量的开头.想法是返回新插入对象的索引.

当我说出这样的代码时,一切都很完美

const_iterator (or auto) it = insert(object);
return it - begin();
Run Code Online (Sandbox Code Playgroud)

但是,如果我尝试制作一个衬里

return insert(object) - begin();
Run Code Online (Sandbox Code Playgroud)

我得到前面提到的"矢量迭代器不兼容"断言.

begin()实现为:

MyClass::iterator MyClass::begin()
{
  return m_container.begin();
}
Run Code Online (Sandbox Code Playgroud)

和insert()实现为:

MyClass::iterator MyClass::insert(MyObject *object)
{
  if (object)
  {
    const_iterator it = std::lower_bound(begin(), end(), object, DereferencedLess<MyObject >());

    if (it == end() || *(*it) != *object)
      return m_container.insert(it, object);
  }

  return end();
}
Run Code Online (Sandbox Code Playgroud)

课程简介:

MyClass {
  ...
  iterator  begin();
  const_iterator begin() const;
  iterator  insert(MyObject*);

  ...
  protected:
  std::vector<MyObject*> m_container;
}
Run Code Online (Sandbox Code Playgroud)

为了完整起见

template<typename T>
struct DereferencedLess …
Run Code Online (Sandbox Code Playgroud)

c++ stl visual-c++ visual-studio-2013

3
推荐指数
1
解决办法
101
查看次数

标签 统计

c++ ×1

stl ×1

visual-c++ ×1

visual-studio-2013 ×1