首页 > STL > set容器 阅读:2,863

C++ set迭代器(STL set迭代器)详解

< 上一页C++ set用法 C++ set保存指针下一页 >

set<T> 容器的成员返回的迭代器都是双向迭代器。这些迭代器的类型的别名定义在 set<T> 模板中,可以从 set 中得到类型别名有 iterator、reverse_iterator、const_iterator、 const_reverse_iterator,从它们的名称就可以看出它们的类型。例如:
  • 成员函数 begin() 和 end() 会返回 iterator 类型的迭代器;
  • 成员函数 rbegin() 和 rend() 会返回 reverse_iterator 类型的迭代器;
  • 成员函数 cbegin() 和 cend() 会返回 const_iterator 类型的迭代器。
  • 成员函数 crbegin() 和 crend() 可以返回 const_reverse_iterator 类型的迭代器。

然而,set 容器的迭代器类型的别名有时会让人产生一些误解。所有 set<T> 容器的成员函数返回的迭代器都指向 const T 类型的元素。因此,iterator 迭代器会指向 const 元素, reverse_iterator 和其他类型的迭代器也是如此。这意味着我们不能修改元素。如果想要修改 set 容器中的元素,必须先删除它,然后再插入修改后的版本。

仔细思考一下,其实这是不合理的。set 中的对象以它们自己作为键,对象在容器中的位置是通过比较对象决定的。如果可以修改元素,元素的顺序就失效了,也会扰乱后面的访问操作。、

当必须修改元素而且仍然需要将它们组合到一个或多个 set 容器中时,还有一个方法可以做到这一点。可以在 set 容器中保存指针,并且最好选择智能指针。当使用 set 容器时,通常会在它们中保存 shared_ptr<T> 或 weak_ptr<T> 对象。

在 set 容器中保存 unique_ptr<T> 对象没有多少意义。因为容器中不存在和 unique_ptr<T> 对象匹配的独立键,所以我们从来不会直接检索元素。
< 上一页C++ set用法 C++ set保存指针下一页 >

编程帮,一个分享编程知识的公众号。跟着站长一起学习,每天都有进步。

通俗易懂,深入浅出,一篇文章只讲一个知识点。

文章不深奥,不需要钻研,在公交、在地铁、在厕所都可以阅读,随时随地涨姿势。

文章不涉及代码,不烧脑细胞,人人都可以学习。

当你决定关注「编程帮」,你已然超越了90%的程序员!

编程帮二维码
微信扫描二维码关注

QQ交流群