C++ set迭代器(STL set迭代器)详解
set<T> 容器的成员返回的迭代器都是双向迭代器。这些迭代器的类型的别名定义在 set<T> 模板中,可以从 set 中得到类型别名有 iterator、reverse_iterator、const_iterator、 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> 对象匹配的独立键,所以我们从来不会直接检索元素。
- 成员函数 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语言入门
- C语言编译器
- C语言项目案例
- 数据结构
- C++
- STL
- C++11
- socket
- GCC
- GDB
- Makefile
- OpenCV
- Qt教程
- Unity 3D
- UE4
- 游戏引擎
- Python
- Python并发编程
- TensorFlow
- Django
- NumPy
- Linux
- Shell
- Java教程
- 设计模式
- Java Swing
- Servlet
- JSP教程
- Struts2
- Maven
- Spring
- Spring MVC
- Spring Boot
- Spring Cloud
- Hibernate
- Mybatis
- MySQL教程
- MySQL函数
- NoSQL
- Redis
- MongoDB
- HBase
- Go语言
- C#
- MATLAB
- JavaScript
- Bootstrap
- HTML
- CSS教程
- PHP
- 汇编语言
- TCP/IP
- vi命令
- Android教程
- 区块链
- Docker
- 大数据
- 云计算