【C++指南】STL list容器完全解读(一):从入门到掌握基础操作

【C++指南】STL list容器完全解读(一):从入门到掌握基础操作
.💓 博客主页:倔强的石头的ZEEKLOG主页
📝Gitee主页:倔强的石头的gitee主页
⏩ 文章专栏:《C++指南》
期待您的关注

文章目录

一、初识list容器

1.1 什么是list?

在C++标准模板库(STL)中,list是一个基于双向链表实现的序列容器。它允许在任意位置进行高效插入和删除操作,时间复杂度为O(1)。与vector不同,list不保证元素在内存中的连续存储,因此不支持随机访问。

在这里插入图片描述

1.2 核心特性

  • 双向链表结构:每个元素包含指向前后节点的指针
  • 动态内存分配:元素按需分配内存
  • 高效插入删除:无需移动其他元素
  • 迭代器稳定性:插入删除操作不会使已有迭代器失效(除被删除元素)

1.3 典型应用场景

  • 需要频繁在首尾之外的位置插入/删除元素
  • 元素体积较大,避免vector扩容时的拷贝开销
  • 需要维护元素的插入顺序
  • 需要合并、拆分链表等特殊操作

二、核心成员函数

2.1 默认成员函数

在这里插入图片描述


构造函数的重载版本

在这里插入图片描述
函数功能描述示例
默认构造函数创建空listlist<int> lst1;
填充构造函数创建包含n个元素的listlist<char> lst2(5);
拷贝构造函数复制另一个list的内容list<int> lst3(lst2);
移动构造函数(C++11)转移另一个list的资源list<int> lst4(move(lst3));
析构函数自动释放内存(通常无需手动调用)lst1.~list();
拷贝赋值运算符深拷贝赋值操作lst2 = lst1;
移动赋值运算符(C++11)高效转移资源赋值操作lst3 = move(lst2);
// 初始化列表构造(C++11) list<string> fruits {"apple","banana","cherry"};

三、迭代器操作

在这里插入图片描述

3.1 基础迭代器

函数功能示例
begin()返回指向第一个元素的迭代器auto it = lst.begin();
end()返回末尾哨兵迭代器while(it != lst.end())
rbegin()返回反向起始迭代器auto rit = lst.rbegin();
rend()返回反向结束迭代器for(; rit != lst.rend();)

3.2 常量迭代器(C++11)

函数功能示例
cbegin()返回不可修改的正向起始迭代器auto cit = lst.cbegin();
cend()返回不可修改的正向结束迭代器if(cit == lst.cend())
crbegin()返回不可修改的反向起始迭代器auto crit = lst.crbegin();
crend()返回不可修改的反向结束迭代器while(crit != lst.crend())
list<int> nums {1,2,3};// 正向遍历for(auto it = nums.begin(); it != nums.end();++it){ cout <<*it <<" ";// 输出:1 2 3}

四、容量与访问操作

在这里插入图片描述

4.1 容量查询

函数功能示例
size()返回元素数量if(lst.size() > 5)
empty()判断容器是否为空while(!lst.empty())

4.2 元素访问

函数功能示例
front()访问首元素(可修改)lst.front() = 10;
back()访问尾元素(可修改)cout << lst.back();
list<double> temps {36.5,37.1,38.0}; temps.front()=35.9;// 修改首元素 cout <<"当前体温:"<< temps.back();// 输出38.0

五、修改操作详解

在这里插入图片描述

5.1 基础修改函数

函数功能示例
push_front(val)头部插入元素lst.push_front(0);
emplace_front(args)头部直接构造元素lst.emplace_front("test");
pop_front()删除头部元素lst.pop_front();
push_back(val)尾部插入元素lst.push_back(100);
emplace_back(args)尾部直接构造元素lst.emplace_back(1,2);
pop_back()删除尾部元素lst.pop_back();
clear()清空所有元素lst.clear();

push_back vs emplace_back

classStudent{public:Student(int id, string name):id(id),name(name){}private:int id; string name;}; list<Student> roster; roster.push_back(Student(101,"Alice"));// 构造临时对象+拷贝 roster.emplace_back(102,"Bob");// 直接构造(高效)

5.2 高级修改操作

函数功能示例
assign(n, val)用n个val替换内容lst.assign(5, 0);
assign(beg, end)用迭代器范围替换内容lst.assign(vec.begin(), vec.end());
swap(other)交换两个list的内容lst1.swap(lst2);
resize(n)调整元素数量lst.resize(10);
resize(n, val)调整数量并用val填充新增元素lst.resize(15, -1);
list<int> nums; nums.assign({1,2,3});// 内容变为[1,2,3] nums.resize(5);// 变为[1,2,3,0,0] nums.resize(3);// 截断为[1,2,3]

5.3 插入与删除

insert重载版本
iterator insert(iterator pos,const T& val);// 单元素插入voidinsert(iterator pos, size_t n,const T& val);// 批量插入voidinsert(iterator pos, InputIt first, InputIt last);// 范围插入
erase操作
iterator erase(iterator pos);// 删除单个元素 iterator erase(iterator first, iterator last);// 删除区间元素

示例

list<int> data {10,20,30};auto it = data.begin();advance(it,1); data.insert(it,15);// [10,15,20,30] data.insert(it,2,18);// [10,15,18,18,20,30] vector<int> tmp {25,35}; data.insert(data.end(), tmp.begin(), tmp.end());// 末尾追加 data.erase(it);// 删除第二个18

六、特殊成员函数

在这里插入图片描述

6.1 条件操作

函数功能示例
remove(val)删除所有等于val的元素lst.remove(5);
remove_if(pred)删除满足条件的元素lst.remove_if([](int n){ return n%2==0; });
list<int> nums {1,2,3,2,5}; nums.remove(2);// 删除所有2 → [1,3,5] nums.remove_if([](int x){return x>3;});// → [1,3]

6.2 链表特有操作

函数功能示例
unique()删除连续重复元素lst.unique();
merge(other)合并有序链表lst1.merge(lst2);
sort()排序元素(升序)lst.sort();
splice(pos, other)转移另一个链表的元素lst1.splice(it, lst2);
list<int> a {1,3,5}, b {2,4,6}; a.merge(b);// a变为[1,2,3,4,5,6], b为空 a.sort();// 排序(若未有序) list<int> x {10,20}, y {30,40};auto pos = x.begin(); x.splice(pos, y);// x变为[30,40,10,20], y为空

七、总结与进阶

本文详细介绍了C++ list容器的基本特性和使用方法。通过大量的代码示例,我们学习了如何正确使用list进行元素的增删改查操作。list作为STL中重要的序列式容器,其独特的链表结构使其在特定场景下具有不可替代的优势。

在接下来的系列文章中,我们将深入探讨:

  • list的高级应用技巧
  • list在实际项目中的最佳实践案例

下篇预告《【C++指南】C++ list容器完全解读(二):list模拟实现,底层架构揭秘》,我们将通过剖析STL源码实现,带你理解list的底层工作机制

Read more

OpenClaw 完整搭建指南:从零开始打造你的 AI 助手

OpenClaw 完整搭建指南:从零开始打造你的 AI 助手

OpenClaw 完整搭建指南:从零开始打造你的 AI 助手 本文基于实际部署经验,详细介绍 OpenClaw 的安装、配置 GitHub Copilot / Qwen 模型、接入钉钉、解决常见问题,以及搭建本地模型的完整流程。 目录 1. 什么是 OpenClaw 2. 环境准备与安装 3. 配置模型提供商 4. 接入钉钉机器人 5. 钉钉插件常见问题与解决方案 6. 日常使用技巧 7. 搭建本地模型(llama.cpp) 8. 总结与资源 一、什么是 OpenClaw OpenClaw 是一个开源的 AI 助手框架,可以: * 🤖 接入多种大模型(Claude、GPT、Qwen、本地模型等)

By Ne0inhk
构建AI临床副驾驶:基于Go的电子病历智能助手与HIS对接实战(上)

构建AI临床副驾驶:基于Go的电子病历智能助手与HIS对接实战(上)

摘要 本文旨在为医疗信息化开发者提供一套可落地的“AI临床副驾驶”设计方案,通过Go语言构建一个轻量、高效的中间层服务,与医院现有的HIS/EMR系统无缝对接。我们聚焦于三个典型智能场景——复诊记忆延伸、首诊导航提醒、病历质控与术语规范,展示如何在不侵入原有系统的情况下,为医生提供实时、精准的辅助决策信息。文章涵盖总体架构设计、多种HIS对接方式(REST/HL7/FHIR/DB视图)、接口契约定义、关键业务流程、完整的Go代码骨架,以及安全合规、部署运维等实践要点。所有代码均基于生产环境经验提炼,可作为项目直接启动的参考原型。 目录 1. 引言:电子病历的“副驾驶”时代 2. 总体架构:Go中间层 + HIS主系统 1. 设计原则 2. 组件划分

By Ne0inhk
揭秘AI大模型通信机制:深入理解流式传输与数据封装逻辑

揭秘AI大模型通信机制:深入理解流式传输与数据封装逻辑

文章目录 * 前言 * 一、 核心数据传输格式详解 * 1. 请求格式 * 2. 响应格式:非流式 * 3. 响应格式:流式 * 二、 流程图分析:从输入到输出 * 1. 流程逻辑描述 * 2. 流程图 (Mermaid 代码表示) * 三、 原理架构图分析 * 1. 架构层级说明 * 2. 架构图 (Mermaid 代码表示) * 四、 关键技术原理深度解析 * 1. 为什么选择 SSE 而不是 WebSocket? * 2. Token 与数据传输的关系 * 3. 数据压缩 * 五、 总结 前言 Ai聊天工具(如ChatGPT、Claude、文心一言等)的数据传输是核心功能的基石。要深入理解其背后的机制,

By Ne0inhk
人工智能:深度学习中的卷积神经网络(CNN)实战应用

人工智能:深度学习中的卷积神经网络(CNN)实战应用

人工智能:深度学习中的卷积神经网络(CNN)实战应用 1.1 本章学习目标与重点 💡 学习目标:掌握卷积神经网络的核心原理、经典网络架构,以及在图像分类任务中的实战开发流程。 💡 学习重点:理解卷积层、池化层的工作机制,学会使用 TensorFlow 搭建 CNN 模型并完成训练与评估。 1.2 卷积神经网络核心原理 1.2.1 卷积层:提取图像局部特征 💡 卷积层是 CNN 的核心组件,其作用是通过卷积核对输入图像进行局部特征提取。 卷积核本质是一个小型的权重矩阵。它会按照设定的步长在图像上滑动。每滑动一次,卷积核就会与对应区域的像素值做内积运算,输出一个特征值。 这个过程可以捕捉图像的边缘、纹理等基础特征。 ⚠️ 注意:卷积核的数量决定了输出特征图的通道数,数量越多,提取的特征维度越丰富。 ① 定义一个 3×3 大小的卷积核,步长设为 1,填充方式为 SAME

By Ne0inhk