news 2026/4/16 12:12:56

6.STL 容器常用操作速查表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
6.STL 容器常用操作速查表

STL容器常用操作速查表

操作类型

std::vector(动态数组)

std::string(字符串)

std::map<K,V>(有序键值对)

头文件

#include <vector>

#include <string>

#include <map>

创建容器

std::vector<int> vec;(空容器)
std::vector<int> vec{1,2,3};(初始化)

std::string str;(空字符串)
std::string str = "hello";(初始化)

std::map<int, std::string> mp;(空容器)
std::map<int, std::string> mp{{1,"a"},{2,"b"}};(初始化)

添加元素

1. 尾部添加:vec.push_back(10);
2. 指定位置插入:vec.insert(vec.begin()+1, 20);(在第2位插20)

1. 拼接:str += " world";
2. 插入字符:str.insert(2, "xx");(在第3位插xx)
3. 追加字符:str.push_back('!');

1. 直接赋值:mp[101] = "张三";
2. 插入键值对:mp.insert({102, "李四"});(不覆盖已有键)

访问元素

1. 下标访问:vec[0](无越界检查)
2. 安全访问:vec.at(0)(有越界检查)
3. 首尾元素:vec.front()/vec.back()

1. 下标访问:str[0]
2. 安全访问:str.at(0)
3. 首尾字符:str.front()/str.back()

1. 下标访问:mp[101](无键则创建默认值)
2. 查找访问:auto it = mp.find(101); if(it != mp.end()) { it->second; }(推荐,无键不创建)

修改元素

vec[0] = 99;(直接赋值)

str[0] = 'H';(修改字符)
str.replace(0, 2, "HE");(替换子串)

mp[101] = "张三丰";(覆盖已有值)

删除元素

1. 尾部删除:vec.pop_back();
2. 指定位置删除:vec.erase(vec.begin()+1);
3. 清空:vec.clear();

1. 尾部删除:str.pop_back();
2. 删除子串:str.erase(1, 2);(从第2位删2个字符)
3. 清空:str.clear();

1. 按键删除:mp.erase(101);
2. 清空:mp.clear();

获取长度

vec.size()(元素个数)
vec.empty()(是否为空)

str.size()/str.length()(字符数)
str.empty()(是否为空)

mp.size()(键值对个数)
mp.empty()(是否为空)

遍历元素

// 方式1:范围for
for (int num : vec) { ... }
// 方式2:迭代器
for (auto it = vec.begin(); it != vec.end(); ++it) { *it; }

// 范围for
for (char c : str) { ... }
// 迭代器
for (auto it = str.begin(); it != str.end(); ++it) { *it; }

// 范围for(pair.first=键,pair.second=值)
for (auto& pair : mp) { pair.first; pair.second; }
// 迭代器
for (auto it = mp.begin(); it != mp.end(); ++it) { it->first; it->second; }

查找元素

// 需包含
auto it = std::find(vec.begin(), vec.end(), 10);
if (it != vec.end()) { 找到元素 }

// 查找子串位置
size_t pos = str.find("llo");
if (pos != std::string::npos) { 找到子串 }

// 按键查找(核心方式)
auto it = mp.find(101);
if (it != mp.end()) { 找到键值对 }

关键补充说明

  1. 迭代器通用规则:所有STL容器的迭代器都遵循begin()(起始位置)、end()(末尾下一位)规则,end()不指向有效元素,仅作为结束标记;
  2. map的特殊点mp[key]是“读写一体”,读取不存在的键会自动插入该键并赋值默认值(如string为空、int为0),因此只读时优先用find()
  3. 空容器判断:所有容器都可用empty()判断是否为空,比size() == 0更高效;
  4. Qt容器适配:Qt的QVector/QString/QMap操作和上表几乎一致,仅需替换:
    • 头文件:<QVector>/<QString>/<QMap>
    • 输出:用qDebug()替代cout,如qDebug() << vec[0];
    • 特有添加方式:vec << 1 << 2;(Qt容器支持)

总结

  1. 核心操作(创建、添加、访问、遍历、清空)在不同容器中逻辑统一,仅语法细节有差异;
  2. vector/string侧重“有序列表操作”,map侧重“键值对的键查找/删除”;
  3. 遍历优先用范围for(简洁),需要精准控制位置时用迭代器
  4. 查找操作中,string用find()、map用find()、vector需配合<algorithm>std::find()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/7 12:29:08

【读书笔记】《透过佛法看世界》

《透过佛法看世界》书籍分享整理 本书作者&#xff1a;希阿荣博堪布&#xff08;堪布相当于博士学位&#xff09;。 堪布文笔优美&#xff0c;富有现代生活幽默感&#xff0c;熟悉东西方文化&#xff0c;能用通俗易懂的语言讲解佛法对心灵的影响。 分享者此前推荐过堪布的《次第…

作者头像 李华
网站建设 2026/4/11 1:33:42

【Open-AutoGLM智能体电脑使用指南】:手把手教你5步激活AI办公新范式

第一章&#xff1a;Open-AutoGLM智能体电脑的核心理念Open-AutoGLM智能体电脑是一种基于大语言模型&#xff08;LLM&#xff09;驱动的自主计算系统&#xff0c;其核心在于将自然语言理解能力与自动化执行机制深度融合&#xff0c;实现用户意图到操作行为的端到端映射。该系统不…

作者头像 李华
网站建设 2026/4/15 22:05:00

18、Windows XP家庭网络服务、应用与故障排查全解析

Windows XP家庭网络服务、应用与故障排查全解析 1. 服务与应用管理 计算机管理控制台的“服务和应用程序”分支提供了三个管理单元,可用于管理以下Windows应用程序和服务: - 服务 :此管理单元可让你查看和管理Windows服务。服务是提供特定操作系统功能的程序,例如“打…

作者头像 李华
网站建设 2026/4/15 13:36:35

为什么90%的人搭不好Open-AutoGLM?避开这6大常见坑位实现一键部署

第一章&#xff1a;为什么90%的人搭不好Open-AutoGLM&#xff1f; 搭建 Open-AutoGLM 本应是一个高效开启自动化大语言模型开发的起点&#xff0c;但现实中绝大多数用户在初始配置阶段便遭遇失败。问题根源往往不在于工具本身&#xff0c;而在于对环境依赖、模块耦合逻辑以及配…

作者头像 李华
网站建设 2026/4/15 11:14:15

揭秘Open-AutoGLM高效开发秘诀:5步实现智能编程跃迁

第一章&#xff1a;揭秘Open-AutoGLM高效开发的核心理念Open-AutoGLM 是面向生成式语言模型自动化开发的开源框架&#xff0c;其设计哲学聚焦于“极简接口、模块解耦、动态编排”。该框架通过抽象出通用的模型训练、推理与评估流水线&#xff0c;使开发者能够以声明式方式快速构…

作者头像 李华