一、引言:什么是 STL?
STL(Standard Template Library)是 C++ 的核心组成部分,提供了一整套高效、泛型的数据结构与算法。其主要包含:
-
容器(Containers):如
vector,list,map,set等; -
算法(Algorithms):如
sort,find,for_each,accumulate; -
迭代器(Iterators):用来访问容器内容的统一接口;
-
函数对象(Function Objects);
-
适配器(Adapters):如
stack,queue,priority_queue。
图示如下:
lua复制编辑+-----------+ +-------------+ +-------------+
| Containers| <--> | Iterators | <--> | Algorithms |
+-----------+ +-------------+ +-------------+
二、STL 容器详解
1. 顺序容器
容器类型
特点
常见用途
vector
动态数组,支持随机访问
批量存储、快速查找
list
双向链表,支持高效插入
频繁插入删除
deque
双端队列,头尾都快
双向进出队列
示例:使用 vector
cpp复制编辑#include <vector>
#include <iostream>
int main() {
std::vector<int> nums = {1, 2, 3};
nums.push_back(4);
for (int x : nums)
std::cout << x << " ";
}
输出:
复制编辑1 2 3 4
2. 关联容器
容器类型
底层结构
特点
set
红黑树
元素自动排序、无重复
map
红黑树
键值对集合、按键有序
unordered_set
哈希表
插入快、无序、不能排序
unordered_map
哈希表
无序键值对,常数时间查找
示例:使用 map
cpp复制编辑#include <map>
#include <iostream>
int main() {
std::map<std::string, int> ages;
ages["Tom"] = 25;
ages["Alice"] = 30;
for (auto& p : ages)
std::cout << p.first << ": " << p.second << "\n";
}
3. 容器适配器
类型
特点
stack
后进先出
queue
先进先出
priority_queue
元素自动排序(最大优先)
三、算法组件详解
STL 中包含 80+ 个算法,典型算法包括:
类型
代表算法
非修改
find, count, all_of
修改
copy, replace, remove
排序
sort, stable_sort, nth_element
数值运算
accumulate, inner_product
1. 查找元素
cpp复制编辑#include <algorithm>
#include <vector>
#include <iostream>
int main() {
std::vector<int> v = {1, 3, 5, 7};
auto it = std::find(v.begin(), v.end(), 5);
if (it != v.end()) std::cout << "Found: " << *it;
}
2. 排序元素
cpp复制编辑std::sort(v.begin(), v.end()); // 默认升序
std::sort(v.begin(), v.end(), std::greater<int>()); // 降序
3. 统计元素
cpp复制编辑int cnt = std::count(v.begin(), v.end(), 3);
四、迭代器详解
STL 容器的操作几乎都基于迭代器,它是通用的指针抽象。
1. 常见迭代器类型
类型
示例容器
输入迭代器
istream_iterator
输出迭代器
ostream_iterator
前向迭代器
forward_list
双向迭代器
list, set
随机访问迭代器
vector, deque
2. 遍历示例
cpp复制编辑for (auto it = v.begin(); it != v.end(); ++it)
std::cout << *it << "\n";
或使用 range-based for:
cpp复制编辑for (int x : v) std::cout << x << "\n";
3. 反向迭代器
cpp复制编辑for (auto rit = v.rbegin(); rit != v.rend(); ++rit)
std::cout << *rit << "\n";
五、函数对象与 Lambda
STL 算法可接收函数或仿函数参数。
1. 自定义函数对象
cpp复制编辑struct Square {
int operator()(int x) const { return x * x; }
};
2. 使用 Lambda
cpp复制编辑std::for_each(v.begin(), v.end(), [](int x) {
std::cout << x * 2 << " ";
});
六、实战:使用 STL 构建学生成绩管理系统
1. 数据结构设计
cpp复制编辑struct Student {
std::string name;
int score;
};
std::vector<Student> students;
2. 排序成绩
cpp复制编辑std::sort(students.begin(), students.end(), [](const Student& a, const Student& b) {
return a.score > b.score;
});
3. 查找学生
cpp复制编辑auto it = std::find_if(students.begin(), students.end(), [](const Student& s) {
return s.name == "Tom";
});
图示:
css复制编辑[{"Tom", 88}, {"Alice", 95}, {"John", 76}]
↓ sort
[{"Alice", 95}, {"Tom", 88}, {"John", 76}]
七、STL 使用技巧与陷阱
✅ 推荐实践
-
优先使用 STL 替代手写结构;
-
emplace_back()性能优于push_back(); -
使用
reserve()提前分配 vector 空间; -
选择合适容器(如需频繁插入选择 list);
🚫 常见错误
-
修改容器时不注意迭代器失效;
-
排序后未使用
lower_bound; -
比较
map时未重载<;
八、STL 与现代 C++ 结合
-
auto简化迭代器声明; -
range-based for提高代码可读性; -
lambda搭配算法使用更灵活; -
constexpr,structured bindings等可结合使用。
九、STL 的效率分析(vector 为例)
操作
时间复杂度
访问元素
O(1)
尾部插入
O(1) amortized
中间插入
O(n)
删除元素
O(n)
图示:vector 插入流程(动态扩容)
scss复制编辑[1, 2, 3] + push_back(4)
↓ 容量满,重新分配 + 拷贝 + 插入
[1, 2, 3, 4]
十、总结
STL 是 C++ 编程中最强大和最被广泛使用的工具之一。掌握 STL 可以帮助你大幅提升开发效率、减少 Bug 和冗余代码,编写出更现代、易维护、高性能的代码。
学会 STL 就是迈出了现代 C++ 开发的第一步:
-
容器 提供强大结构支持;
-
算法 提供高性能通用逻辑;
-
迭代器 提供灵活的数据访问;
-
函数对象 提供定制化能力。
来源:入口文档
来源:访问资源
来源:数据页面
来源:地址资料
来源:文档参考
来源:通道资源
来源:了解数据
来源:路径数据
来源:信息参考
来源:导向页面
来源:源平台页
来源:参考资源
来源:内容引导
来源:页面文档
来源:资料内容
来源:内容数据
来源:了解页面
来源:平台路径
来源:页面入口
来源:路径入口
来源:地址入口
来源:链接说明
来源:引用信息
来源:页面说明
来源:导向路径
来源:跳转文档
来源:通道详情
来源:数据导向
来源:原文平台
来源:引导文档
来源:页面来源
来源:资源通道
来源:通道导向
来源:信息页面
来源:链接数据
来源:平台详情
来源:源头信息
来源:地址参考
来源:跳转条目
来源:索引内容
来源:详细跳转页
来源:获取跳转
来源:导航信息
来源:内容数据页
来源:更多条目
来源:参考来源
来源:访问条目
来源:文章详情页
来源:文稿内容
来源:参考渠道
来源:页面链接
来源:内容资源
来源:获取入口
来源:详情数据
来源:文章出处
来源:参考信息
来源:资源内容
来源:说明通道
来源:入口内容
来源:信息页跳转
来源:链接内容
来源:文档渠道
来源:内容说明
来源:文章获取
来源:详情跳转
来源:资料通道
来源:页面获取
来源:信息数据
来源:信息内容
来源:文档页
来源:资料页
来源:数据详情
来源:渠道文档
来源:浏览资源
来源:详情资源
来源:链接渠道
来源:资源获取
来源:出处入口
来源:文档路径
来源:参考详情
来源:阅读入口
来源:文段通道
来源:文页信息
来源:文稿资源
来源:文章数据
来源:资源页
来源:参考条目
来源:访问页面
来源:资料页跳转
来源:参考出处
来源:信息源
来源:原始资料
来源:相关内容
来源:参考路径
来源:了解文档
来源:资料通道页
来源:文章索引
来源:浏览条目
来源:说明信息
来源:文章文档
来源:阅读资料
来源:条目信息
来源:展示内容
来源:入口通道
来源:文稿页
来源:条目跳转
来源:信息页链接
来源:访问内容
来源:参考页面
来源:内容素材
来源:文档条目
来源:路径说明
来源:资源来源
来源:展示页面
来源:资源链接
来源:内容段落
来源:入口来源
来源:信息获取
来源:资源入口
来源:条目内容
来源:文章渠道
来源:入口跳转
来源:资源文稿
来源:资料索引
来源:获取详情
来源:数据源
来源:渠道入口
来源:资料数据
来源:资源片段
来源:资料展示
来源:内容文章
来源:内容段
来源:条目展示
来源:文段入口
来源:素材链接
来源:条目资源
来源:详情入口
来源:素材内容
来源:段落入口
来源:入口条目
来源:链接渠道页
来源:数据详情页
来源:文页通道
来源:文档原文
来源:原文页
来源:文稿入口
来源:资源数据页
来源:条目文献
来源:段落链接
来源:信息片段
来源:信息展示
来源:详情页面
来源:源文入口
来源:语段入口
来源:资源页面
来源:参考链接
来源:数据片段
来源:片段详情
来源:入口数据
来源:访问路径
来源:数据展示
来源:段落数据
来源:参考信息页
来源:信息源页
来源:条目索引
来源:条目片段
来源:索引入口
来源:路径内容
来源:素材页面
来源:路径详情
来源:资源说明页
来源:文稿详情
来源:文档信息
来源:链接信息
来源:获取数据
来源:参考数据
来源:访问展示
来源:入口展示
来源:访问素材
来源:入口文页
来源:参考段落
来源:内容库
来源:素材页
来源:素材数据
来源:语料内容
来源:跳转素材
来源:资料库
来源:文库链接
来源:渠道内容
来源:渠道说明
来源:展示页
来源:访问素材页
来源:素材入口
来源:文档链接
来源:数据通道
来源:信息路径
来源:素材展示
来源:文稿展示
来源:内容渠道
来源:文段展示
来源:素材说明
来源:素材展示页
来源:资源通道页
来源:路径资源
来源:获取原文
来源:索引内容页
来源:信息入口页
来源:资源页跳转
来源:内容链接页
来源:资源展示页
来源:信息展示页
来源:资料路径
来源:获取文章
来源:内容参考页
来源:文章跳转页
来源:素材入口页
来源:文档展示页
来源:渠道跳转页
来源:数据资源页
来源:段落展示页
来源:语段展示页
来源:跳转资料页
来源:入口信息页
来源:展示资源页
来源:资源路径
来源:片段展示页
来源:资料展示页
来源:内容说明页
来源:数据页链接
来源:链接资料页
来源:展示内容页
来源:通道入口页
来源:原文展示页
来源:数据链接页
来源:内容链接通道
来源:内容展示页
来源:跳转信息页
来源:说明内容页
来源:文章展示页
来源:素材链接页
来源:参考展示页
来源:信息跳转页
来源:渠道链接页
来源:详情展示页
来源:展示文档页
来源:信息数据页
来源:素材数据页
来源:片段链接页
来源:资料跳转通道
来源:展示文稿页
来源:信息渠道页
来源:渠道数据页
来源:条目展示页
来源:文库入口页
来源:数据说明页
来源:内容跳转页
来源:资料浏览
来源:内容索引
来源:路径页面
来源:资源概览
来源:参考素材
来源:文章链接
来源:原始文段
来源:文库索引
来源:资料路径页
来源:内容引用
来源:资源文段
来源:跳转资料
来源:链接入口页
来源:资料内容页
来源:文档访问
来源:资料详情页
来源:文库页面
来源:内容入口页
来源:段落资源
来源:条目链接
来源:内容详情页
来源:入口文库
来源:素材文段
来源:片段页面
来源:段落素材
来源:素材参考
来源:链接条目页
来源:文章内容页
来源:展示信息页
来源:参考段落页
来源:原始片段
来源:片段入口页
来源:文段链接页
来源:数据引用
来源:数据参考页
来源:原始内容页
来源:资源引用
来源:链接参考页
来源:资料引用
来源:入口索引页
来源:资源参考页
来源:展示入口页
来源:跳转链接页
来源:详情路径页
来源:路径通道页
来源:说明链接页
来源:索引文段
来源:入口文段
来源:内容引用页
来源:资源访问页
来源:访问详情页
来源:资料详情信息
来源:段落条目页
来源:说明通道页
来源:文章片段页
来源:展示索引页
来源:内容资源页
来源:资源页通道
来源:跳转索引页
来源:获取链接
来源:链接获取页
来源:内容详情信息
来源:原始数据页
来源:参考片段
来源:条目内容页
来源:段落跳转页
来源:段落链接通道
来源:条目引用
来源:内容提要页
来源:资源浏览页
来源:资料获取页
来源:片段索引页
来源:文库参考
来源:说明文章
来源:入口展示页
来源:信息获取页
来源:内容通道页
来源:说明参考页
来源:资料文稿页
来源:参考内容页
来源:通道展示页
来源:页面片段
来源:素材索引页
来源:通道资料页
来源:链接文章页
来源:展示说明页
来源:资料语段
来源:资源段落
来源:资料语料页
来源:信息详情页
来源:参考展示内容
来源:资料数据页
来源:通道跳转页
来源:原始数据内容
来源:说明资源页
来源:展示内容信息
来源:展示片段页
来源:资料通道链接
来源:访问通道页
来源:链接展示页
来源:说明资料页
来源:数据展示信息
来源:原文跳转页
来源:素材链接通道
来源:内容片段展示
来源:展示资料信息
来源:展示资源内容
来源:信息索引页
来源:素材参考页
来源:展示数据内容
来源:链接通道展示
来源:链接信息展示
来源:信息参考内容
来源:资源跳转信息
来源:条目跳转链接
来源:文档跳转信息
来源:片段跳转链接
来源:语段展示内容
来源:内容跳转展示
来源:页面跳转链接
来源:资料页面信息
来源:原文跳转链接
来源:条目跳转内容
来源:数据页展示链接
来源:链接内容展示页
来源:链接条目展示页
来源:信息跳转通道页
来源:资料跳转展示内容
来源:链接内容展示信息
来源:展示入口链接页面
来源:内容入口链接页面
来源:展示资料跳转链接
来源:入口展示跳转链接
来源:数据资料跳转链接
来源:入口内容跳转链接
来源:信息入口跳转链接
来源:路径入口跳转链接
来源:入口路径跳转链接
来源:通道入口跳转链接
来源:文稿内容跳转链接
来源:资料信息跳转链接
来源:数据内容跳转链接
来源:入口数据跳转链接
来源:文章信息跳转链接
来源:展示信息跳转链接
来源:展示资料入口链接
来源:内容链接入口展示页
来源:入口通道资源展示页
来源:参考来源入口展示链接
来源:内容资料跳转链接页面
来源:通道资源展示跳转链接
来源:链接文章入口资料页面
来源:访问通道信息展示链接
来源:文章展示页面跳转链接
来源:展示信息链接资源入口
来源:入口链接展示信息资源
来源:资料链接跳转展示通道
来源:文章入口跳转资料页面
来源:链接文章入口资源页面
来源:跳转文章入口链接资料
来源:资料跳转资源入口链接
来源:文档内容跳转链接入口
来源:资料链接展示入口页面
来源:数据入口展示资料链接
来源:展示资源链接跳转页面
来源:信息入口展示跳转链接
来源:资源跳转入口展示链接
来源:展示资源入口链接页面
来源:资料展示跳转链接入口
来源:资源展示跳转链接入口
来源:跳转链接展示资源页面
来源:链接资源展示页面入口
来源:展示入口链接跳转资源
来源:链接入口跳转资源展示
来源:页面入口链接跳转展示
来源:资源跳转链接入口页面
来源:内容跳转入口链接展示
来源:文章展示跳转资源入口
来源:链接展示入口跳转资源
来源:跳转资料展示入口链接
来源:跳转入口展示链接资源
来源:信息资源跳转入口链接
来源:资料展示入口链接页面
来源:跳转链接入口展示资料
来源:资料链接入口展示页面
来源:资源展示链接入口页面
来源:入口链接展示资料资源
来源:资源展示资料链接入口
来源:跳转链接资源入口展示
来源:链接展示资料资源入口
来源:入口展示资料链接资源
来源:相关阅读
来源:资料出处
来源:资料来源
来源:内容参考
来源:延伸阅读
来源:推荐链接
来源:相关信息
来源:参考内容
来源:推荐资料
来源:详细内容
来源:更多内容
来源:查看详情
来源:点击查看
来源:深入了解
来源:官方资料
来源:资料链接
来源:信息来源
来源:阅读更多
来源:文献出处
来源:内容链接
来源:数据出处
来源:技术参考
来源:案例来源
来源:实证依据
来源:报告链接
来源:研究链接
来源:统计数据
来源:数据来源
来源:分析资料
来源:理论出处
来源:论文参考
来源:说明详情
来源:调研内容
来源:支持数据
来源:背景文献
来源:学术出处
来源:报告来源
来源:文献引用
来源:权威来源
来源:实测数据
来源:延伸信息
来源:详情参考
来源:原文链接
来源:看原文
来源:阅读原文
来源:查看原帖
来源:原帖地址
来源:原始出处
来源:相关原文
来源:官方信息
来源:经验来源
来源:更多解析
来源:看更多
来源:网页资料
来源:实用信息
来源:入门参考
来源:指南文档
来源:推荐文章
来源:实例出处
来源:小贴士
来源:快速了解
来源:点此查看
来源:点击跳转
来源:原始链接
来源:网页参考
来源:本文依据
来源:内容跳转
来源:参考文档
来源:跳转详情
来源:网页原文
来源:链接详情
来源:点击去看
来源:点我查看
来源:来源说明
来源:资讯入口
来源:阅读跳转
来源:入门来源
来源:学习资料
来源:背景说明
来源:研究出处
来源:信息拓展
来源:衍生阅读
来源:延展资料
来源:链接来源
来源:原始内容
来源:探索原文
来源:获取信息
来源:查阅资料
来源:获取来源
来源:扩展阅读
来源:查阅详情