STL —— 核心组成部分和特性概述

server/2025/3/13 13:48:22/

        C++ 标准模板库(Standard Template Library, STL)是 C++ 标准库的核心组成部分,提供了一系列通用、高效的模板化数据结构和算法。它的设计基于泛型编程思想,通过高度解耦的组件实现了代码复用和灵活性。以下是 STL 的核心组成部分和特性概述:


目录

1. 核心组件

(1) 容器(Containers)

(2) 迭代器(Iterators)

(3) 算法(Algorithms)

(4) 函数对象(Functors)与 Lambda

(5) 适配器(Adapters)

2. 关键特性

(1) 泛型编程

(2) 高性能

(3) 可扩展性

3. 常用容器性能对比

4. 典型代码示例

5. 注意事项


1. 核心组件

(1) 容器(Containers)

  • 作用:存储和管理数据的对象。

  • 分类

    • 顺序容器:线性排列元素(如 vectorlistdequearrayforward_list)。

    • 关联容器:基于键(Key)有序存储(如 setmapmultisetmultimap)。

    • 无序关联容器:基于哈希表的无序存储(如 unordered_setunordered_map)。

    • 容器适配器:对底层容器的封装(如 stackqueuepriority_queue)。

(2) 迭代器(Iterators)

  • 作用:提供对容器元素的统一访问接口,充当容器与算法之间的桥梁。

  • 类型

    • 输入迭代器(只读)、输出迭代器(只写)

    • 前向迭代器(单向遍历)、双向迭代器(支持反向)、随机访问迭代器(支持跳跃访问)。

  • 示例

    vector<int> vec = {1, 2, 3};
    for (auto it = vec.begin(); it != vec.end(); ++it) {cout << *it << " ";  // 输出: 1 2 3
    }

(3) 算法(Algorithms)

  • 作用:操作容器中的元素,如排序、查找、遍历等。

  • 特点:通过迭代器与容器解耦,不依赖具体容器类型。

  • 常见算法

    • sort()find()reverse()copy()transform()accumulate()

(4) 函数对象(Functors)与 Lambda

  • 函数对象:重载了 operator() 的类,可像函数一样调用(如 greater<int> 用于降序排序)。

  • Lambda 表达式(C++11):匿名函数,简化算法的定制操作。

    vector<int> nums = {3, 1, 4};
    sort(nums.begin(), nums.end(), [](int a, int b) { return a > b; }); // 降序排序

(5) 适配器(Adapters)

  • 作用:修改组件接口(如 stack 基于 deque 实现,但限制为后进先出操作)。


2. 关键特性

(1) 泛型编程

  • 通过模板(Templates)实现类型无关的代码,例如 vector<int> 和 vector<string> 使用同一套实现逻辑。

(2) 高性能

  • 容器和算法经过高度优化(如 vector 的连续内存访问、unordered_map 的哈希表平均 O(1) 查找)。

(3) 可扩展性

  • 允许用户自定义容器、迭代器或函数对象,并与 STL 协同工作。


3. 常用容器性能对比

容器插入/删除时间复杂度随机访问底层结构
vector尾部 O(1),其他 O(n)O(1)动态数组
listO(1)不支持双向链表
deque头尾 O(1)O(1)分块数组
map/setO(log n)不支持红黑树
unordered_map平均 O(1)不支持哈希表

4. 典型代码示例

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;int main() {// 容器与算法结合vector<int> vec = {5, 2, 8, 1, 9};sort(vec.begin(), vec.end());  // 升序排序// 使用 Lambda 表达式过滤偶数auto it = remove_if(vec.begin(), vec.end(), [](int x) { return x % 2 != 0; });vec.erase(it, vec.end());// 输出结果:2 8for (auto num : vec) {cout << num << " ";}return 0;
}

5. 注意事项

  1. 迭代器失效:在修改容器(如 vector 扩容)时,原有迭代器可能失效。

  2. 容器选择:根据场景选择合适容器(如频繁插入删除用 list,快速查找用 unordered_map)。

  3. 范围操作算法通常作用于迭代器范围([begin, end))。

  4. C++11 增强:如 emplace 系列函数减少拷贝开销,右值引用优化资源管理。


http://www.ppmy.cn/server/174634.html

相关文章

《鸿蒙系统下AI模型训练加速:时间成本的深度剖析与优化策略》

在当今数字化浪潮中&#xff0c;鸿蒙系统凭借其独特的分布式架构与强大的生态潜力&#xff0c;为人工智能的发展注入了新的活力。随着AI应用在鸿蒙系统上的日益普及&#xff0c;如何有效降低模型训练的时间成本&#xff0c;成为了开发者与研究者们亟待攻克的关键课题。这不仅关…

洗鞋小程序(源码+文档+讲解+演示)

引言 随着生活水平的提高&#xff0c;人们对洗鞋服务的需求日益增长。洗鞋小程序作为一个智能化平台&#xff0c;为用户提供了便捷、高效的洗鞋服务。本文将详细介绍该小程序的功能、技术架构以及其在提升用户体验中的优势。 系统概述 洗鞋小程序采用前后端分离的架构设计&a…

Zookeeper相关面试题

以下是150道Zookeeper相关面试题&#xff1a; Zookeeper基础概念 1. Zookeeper是什么&#xff1f; Zookeeper是一个开源的分布式协调服务&#xff0c;用于管理分布式系统中的配置、命名、分布式锁等功能。 2. Zookeeper的主要功能有哪些&#xff1f; • 配置管理 • 分布式…

如何应对Maven中的依赖导入挑战?

在软件开发的世界里&#xff0c;Maven作为一个流行的项目管理工具&#xff0c;为开发者提供了便利&#xff0c;特别是在管理依赖方面。不过&#xff0c;在使用Maven的过程中&#xff0c;依赖导包问题常常困扰着很多开发者。这些问题可能会导致项目构建失败、运行时错误&#xf…

ranger集成starrock报错

org.apache.ranger.plugin.client.HadoopException: initConnection: Unable to connect to StarRocks instance, please provide valid value of field : {jdbc.driverClassName}.. com.mysql.cj.jdbc.Driver. 可能的原因 JDBC 驱动缺失&#xff1a;运行环境中没有安装 MySQL …

动态IP/静态IP

目录 动态IP 特点&#xff1a; 优点&#xff1a; 缺点&#xff1a; 适用场景&#xff1a; 静态IP 特点&#xff1a; 优点&#xff1a; 缺点&#xff1a; 适用场景&#xff1a; 动态IP 特点&#xff1a; 自动分配&#xff1a;由ISP&#xff08;互联网服务提供商&…

golang中具有 “no copy“的类型

在 Go 语言中&#xff0c;某些类型由于特殊用途或底层实现&#xff0c;可能会被标记为 “no copy”&#xff0c;即它们不能被复制&#xff0c;通常是因为复制会导致意外的行为或错误。这些类型主要包括&#xff1a; 1. sync.Mutex、sync.RWMutex 原因&#xff1a;Mutex 是用于…

Pytorch实现之利用普通GAN的人脸修复

简介 简介:利用遮挡真实样本的部分面貌,输入给生成器,让生成器输出未被遮挡的面貌,以达到修复人脸的效果。 论文题目:FACE RESTORATION VIA GENERATIVE ADVERSARIAL NETWORKS(基于生成对抗网络的人脸恢复) 会议:2023 Third International Conference on Secure Cybe…