【C++ 面试 - STL】每日 3 题(八)

✍个人博客:Pandaconda-CSDN博客

📣专栏地址:http://t.csdnimg.cn/fYaBd

📚专栏简介:在这个专栏中,我将会分享 C++ 面试中常见的面试题给大家~

❤️如果有收获的话,欢迎点赞👍收藏📁,您的支持就是我创作的最大动力💪

22. 迭代器用过吗?什么时候会失效?

用过,常用容器迭代器失效情形如下。

  1. 对于序列容器 vector,deque 来说,使用 erase 后,后边的每个元素的迭代器都会失效,后边每个元素都往前移动一位,erase 返回下一个有效的迭代器。
  2. 对于关联容器 map,set 来说,使用了 erase 后,当前元素的迭代器失效,但是其结构是红黑树,删除当前元素,不会影响下一个元素的迭代器,所以在调用 erase 之前,记录下一个元素的迭代器即可。
  3. 对于 list 来说,它使用了不连续分配的内存,并且它的 erase 方法也会返回下一个有效的迭代器,因此上面两种方法都可以使用。

23. vector 在扩容的时候,迭代器会失效吗?

是的,在 C++ 中,当使用 std::vector 进行扩容时,迭代器会失效。

扩容是指当 vector 的当前容量不足以容纳新插入的元素时,vector 会重新分配一块更大的内存并将所有元素复制到新的内存中。在这个过程中,原来的迭代器指向的位置可能会发生变化,导致迭代器失效。

如果对 vector 进行插入操作,并在插入前保存了迭代器,那么插入新元素后,你保存的迭代器将不再准确。因此,如果在插入操作后需要继续使用迭代器,需要注意在扩容前先更新迭代器,或者使用索引来引用元素。

在编写代码时,可以通过以下几种方式来避免迭代器失效的问题:

  1. 使用索引替代迭代器:在插入新元素后,如果需要继续使用迭代器进行操作,可以在插入前先保存迭代器的位置,然后使用索引来引用元素。例如:
cpp 复制代码
std::vector<int> vec = {1, 2, 3};
auto it = vec.begin();
vec.push_back(4);
// 使用索引来引用元素
int value = vec[0];
  1. 使用返回值的迭代器:在插入操作后,std::vector 的成员函数会返回一个指向新插入元素的迭代器。可以使用返回的迭代器来继续操作。例如:
cpp 复制代码
std::vector<int> vec = {1, 2, 3};
auto it = vec.insert(vec.begin() + 1, 5);  // 在第二个位置插入5
// 使用返回的迭代器继续操作
vec.erase(it);  // 删除新插入的元素
  1. 利用循环的特性:可以通过逆序循环遍历 vector,这样在插入新元素时,迭代器不会失效。例如:
cpp 复制代码
std::vector<int> vec = {1, 2, 3};
for (auto it = vec.rbegin(); it != vec.rend(); ++it) {
   if ((*it) == 2) {
       vec.insert(it.base(), 4);  // 在2的后面插入4
   }
}

24. 说一下 STL 中迭代器的作用,有指针为何还要迭代器?

  1. 迭代器的作用
    (1)用于指向顺序容器和关联容器中的元素
    (2)通过迭代器可以读取它指向的元素
    (3)通过非 const 迭代器还可以修改其指向的元素
  2. 迭代器和指针的区别
    迭代器不是指针,是类模板,表现的像指针。他只是模拟了指针的一些功能,重载了指针的一些操作符,-->、++、-- 等。迭代器封装了指针,是一个 "可遍历 STL( Standard Template Library)容器内全部或部分元素" 的对象,本质是封装了原生指针,是指针概念的一种提升,提供了比指针更高级的行为,相当于一种智能指针,他可以根据不同类型的数据结构来实现不同的 ++,-- 等操作。
    迭代器返回的是对象引用而不是对象的值,所以 cout 只能输出迭代器使用取值后的值而不能直接输出其自身。
  3. 迭代器产生的原因
    Iterator 类的访问方式就是把不同集合类的访问逻辑抽象出来,使得不用暴露集合内部的结构而达到循环遍历集合的效果。
相关推荐
Dovis(誓平步青云)8 分钟前
探索C++标准模板库(STL):String接口的底层实现(下篇)
开发语言·c++·stl·string
海棠一号12 分钟前
JAVA理论第五章-JVM
java·开发语言·jvm
zhuyasen23 分钟前
深度定制 protoc-gen-go:实现结构体字段命名风格控制
后端·go·protobuf
eternal__day29 分钟前
Spring Cloud 多机部署与负载均衡实战详解
java·spring boot·后端·spring cloud·负载均衡
笑鸿的学习笔记36 分钟前
虚幻引擎5-Unreal Engine笔记之SET节点的输出引脚获取设置后的最新变量值
笔记·ue5·虚幻
Livingbody39 分钟前
whisper 命令行解析【2】
后端
何中应40 分钟前
【设计模式-5】设计模式的总结
java·后端·设计模式
草莓熊Lotso41 分钟前
【数据结构初阶】--算法复杂度的深度解析
c语言·开发语言·数据结构·经验分享·笔记·其他·算法
KyollBM1 小时前
【CF】Day75——CF (Div. 2) B (数学 + 贪心) + CF 882 (Div. 2) C (01Trie | 区间最大异或和)
c语言·c++·算法
海的诗篇_1 小时前
前端开发面试题总结-JavaScript篇(二)
开发语言·前端·javascript·typescript