【C++】<STL部分>:STL标准模板库概要

STL(standard template libaray-标准模板库),是C++标准库的重要组成部分,包含了很多常用的数据结构和算法。

在我们学习了模板的之后,再来看STL,就能知道它是C++标准库中的模板类和模板函数的集合,作为可复用的库大大提高了程序员的工作效率。

STL主要组成包括:

  • 容器(Containers):封装各种数据结构,如数组、链表、集合等。
  • 算法(Algorithms):提供排序、查找、拷贝、合并等通用算法。
  • 迭代器(Iterators):连接容器与算法的桥梁,用来遍历容器。
  • 函数对象(Function Objects / Functors):行为像函数的对象,用于定制算法行为。
  • 适配器(Adapters):对已有组件进行封装,使其接口发生变化(如 stack、queue)。
  • 分配器(Allocators):负责内存分配,通常使用默认的分配器。

概要如下图所示:

image-20250407200654017

说到STL,就不得不说到泛型编程,这也是上次提到过的一种编程方式。具体可以查看:【C++】Chaper03 函数模板与泛型-CSDN博客

接下来进行几个部分的大致介绍。

一、STL容器

容器大致分为三类,分别是序列式容器、关联式容器、无序容器。

1. 序列式容器(Sequence Containers)

保持元素的排列顺序。

  • vector:动态数组,支持随机访问,尾部插入删除高效。
  • deque:双端队列,头尾插入删除都高效。
  • list:双向链表,任意位置插入删除高效,但不支持随机访问。
  • forward_list:C++11引入,单向链表。
  • array:定长数组,C++11引入。

2. 关联式容器(Associative Containers)

自动按键排序(通常为红黑树实现)。

  • set:键的集合,不允许重复。
  • multiset:允许重复键。
  • map:键值对,键唯一。
  • multimap:键值对,键可重复。

3. 无序容器(Unordered Containers)

基于哈希表实现,C++11 引入。

  • unordered_setunordered_multiset
  • unordered_mapunordered_multimap

二、迭代器(Iterators)

STL中的迭代器类似于指针,用于访问容器中的元素。

常见迭代器类型:

  • input_iterator:只读,单向(如 istream_iterator)
  • output_iterator:只写,单向(如 ostream_iterator)
  • forward_iterator:可读写,单向(如 forward_list)
  • bidirectional_iterator:双向(如 list)
  • random_access_iterator:随机访问(如 vector、deque)

三、STL算法(Algorithms)

STL 提供了约 60 多种通用算法,主要分为以下几类:

  • 非变序算法:不修改原始容器内容(如 findcountfor_each
  • 变序算法:可能会修改容器(如 copyreplaceremove
  • 排序和比较sortstable_sortminmax
  • 数值算法accumulateinner_product(需 #include <numeric>

四、函数对象(Function Objects)

函数对象是重载了 operator() 的类或结构体,可以像函数一样调用。常用于定制排序规则等。

例如:

struct MyCompare {bool operator()(int a, int b) {return a > b; // 降序}
};std::sort(vec.begin(), vec.end(), MyCompare());

五、适配器(Adapters)

对现有的容器或函数进行封装,改变其接口。

  • 容器适配器stackqueuepriority_queue
  • 迭代器适配器reverse_iteratorinsert_iterator
  • 函数适配器bindnot1mem_fun(C++11推荐使用 std::bind 和 Lambda)

六、分配器(Allocators)

用于抽象和管理内存的分配与释放。一般用默认的分配器,但也可以自定义内存管理策略。

标准分配器 std::allocator :

std::allocator 是 C++ 标准库提供的默认分配器,实现了最基本的内存分配和对象管理功能。其定义位于头文件 中。主要成员函数包括:

  • allocate:分配未构造的内存。
  • deallocate:释放先前分配的内存。
  • construct:在已分配的内存上构造对象(C++17 之前)。
  • destroy:调用对象的析构函数(C++17 之前)2。

自定义分配器:

自定义分配器允许开发者控制内存管理策略。例如,可以实现一个内存池分配器,以减少频繁的内存分配和释放带来的开销。

STL的优点与缺点

STL的优点与缺点

优点:

  • 高效:模板和内联使得STL非常高效。
  • 通用:一套算法可作用于不同容器。
  • 易用:编写高质量代码更容易。

缺点:

  • 编译慢:模板膨胀严重。
  • 错误提示晦涩难懂。
  • 可定制性有限(例如自定义内存管理复杂)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/900464.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从传递函数到PID控制器

在过程控制中&#xff0c;按偏差的比例&#xff08;P&#xff0c;Proportional&#xff09;、积分&#xff08;I&#xff0c;Integral&#xff09;和微分&#xff08;D&#xff0c;Differential&#xff09;进行控制的PID控制器&#xff08;亦称PID调节器&#xff09;是应用最为…

【PVR Review】《A Review of Palmar Vein Recognition》

[1]张秀峰,牛选兵,王伟,等.掌静脉识别研究综述[J].大连民族大学学报,2020,22(01):33-37.DOI:10.13744/j.cnki.cn21-1431/g4.2020.01.007. 文章目录 1、背景2、手掌静脉识别方法2.1、传统手掌静脉图像识别方法2.2、基于深度学习的掌静脉图像识别 3、手掌静脉识别难点 1、背景 目…

vector复制耗时

CPP中的vector对象在传参给子函数时&#xff0c;如果直接传参&#xff0c;会造成复制给形参的额外耗时 如何解决这个问题呢&#xff1f; 这样定义局部函数 const vector <int>&vec可以保证传递vector对象时使用地址传递&#xff0c;并且使用const保证vector不被改变…

算法思想之双指针

文章目录 双指针字符串序列判定字符串所有整数最小和服务交换接口失败率分析分披萨最多团队 双指针 双指针是指在解决问题时使用两个指针&#xff0c;通常分别指向数组或字符串中的不同位置&#xff0c;通过移动这两个指针来解决问题的一种技巧。双指针技巧常用于解决数组、链…

学透Spring Boot — 018. 优雅支持多种响应格式

这是我的专栏《学透Spring Boot》的第18篇文章&#xff0c;想要更系统的学习Spring Boot&#xff0c;请访问我的专栏&#xff1a;学透 Spring Boot_postnull咖啡的博客-CSDN博客。 目录 返回不同格式的响应 Spring Boot的内容协商 控制器不用任何修改 启动内容协商配置 访…

ngx_os_init

定义在 src\os\unix\ngx_posix_init.c ngx_int_t ngx_os_init(ngx_log_t *log) {ngx_time_t *tp;ngx_uint_t n; #if (NGX_HAVE_LEVEL1_DCACHE_LINESIZE)long size; #endif#if (NGX_HAVE_OS_SPECIFIC_INIT)if (ngx_os_specific_init(log) ! NGX_OK) {return NGX_ERR…

深信服护网蓝初面试题

《网安面试指南》https://mp.weixin.qq.com/s/RIVYDmxI9g_TgGrpbdDKtA?token1860256701&langzh_CN 5000篇网安资料库https://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247486065&idx2&snb30ade8200e842743339d428f414475e&chksmc0e4732df793fa3bf39…

游戏引擎学习第206天

回顾并为当天的工作定下目标 接着回顾了前一天的进展。之前我们做了一些调试功能&#xff0c;并且已经完成了一些基础的工作&#xff0c;但是还有一些功能需要继续完善。其中一个目标是能够展示实体数据&#xff0c;以便在开发游戏逻辑系统时&#xff0c;可以清晰地查看和检查…

HTML 表单:构建交互式网页的关键元素

HTML 表单:构建交互式网页的关键元素 引言 HTML表单是构建交互式网页的核心组件之一,它允许用户与网站进行交互,提交信息、填写问卷或进行其他操作。本文将深入探讨HTML表单的基础知识、常用元素、表单验证以及如何优化表单设计,以提高用户体验和网站的可访问性。 HTML表…

Qt音频采集:QAudioInput详解与示例

1. 简介 QAudioInput是Qt Multimedia模块中用于音频采集的核心类&#xff0c;能够从麦克风等输入设备实时获取原始音频数据&#xff08;PCM格式&#xff09;。本文将通过原理讲解和代码示例&#xff0c;帮助开发者快速掌握音频采集的核心技术。 2. 核心功能 支持多种音频格式&…

下载安装Node.js及其他环境

提示&#xff1a;从Node版本降级到Vue项目运行 文章目录 下载Node.js环境配置配置环境变量 安装 cnpm&#xff08;我需要安装&#xff09;安装脚手架安装依赖安装淘宝镜像&#xff08;注意会更新&#xff09;cnpm vs npm 与新旧版本核心差异包管理器不同功能差异如何选择&#…

【后端】ORM / ODM

长期不定期更新&#xff0c;建议关注收藏点赞。 概述 ORM&#xff08;Object-Relational Mapping&#xff0c;对象关系映射&#xff09;&#xff1a;面向关系型数据库&#xff0c;ORM将对象映射到数据库的表和行&#xff08;例如MySQL、PostgreSQL&#xff09;。ODM&#xff0…

无限滚动(Infinite Scroll)页面谷歌不收录!必须改回分页吗?

近三年&#xff0c;全球超过58%的网站采用无限滚动设计&#xff08;数据来源&#xff1a;PageTraffic 2023&#xff09; 谷歌官方数据显示&#xff0c;动态加载内容的索引失败率高达73%&#xff08;Google Webmaster Report 2022&#xff09;&#xff0c;而采用纯无限滚动的页…

手写JSX实现虚拟DOM

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 &#x1f35a; 蓝桥云课签约作者、…

网络性能优化参数关系解读 | TCP Nagle / TCP_NODELAY / TCP_QUICKACK / TCP_CORK

注&#xff1a;本文为 “网路性能优化” 相关文章合辑。 未整理去重。 如有内容异常&#xff0c;请看原文。 TCP_NODELAY 详解 lenky0401 发表于 2012-08-25 16:40 在网络拥塞控制领域&#xff0c;Nagle 算法&#xff08;Nagle algorithm&#xff09;是一个非常著名的算法&…

玄机-应急响应-webshell查杀

题目要求&#xff1a; 要求获取四个flag webshell查杀&#xff1a; 常见的webshell&#xff1a; PHP: eval(), system(), exec(), shell_exec(), passthru(), assert(), base64_decode() ASP: Execute(), Eval(), CreateObject() JSP: Runtime.getRuntime().exec() websh…

docker存储卷及dockers容器源码部署httpd

1. COW机制 Docker镜像由多个只读层叠加而成,启动容器时,Docker会加载只读镜像层并在镜像栈顶部添加一个读写层。 如果运行中的容器修改了现有的一个已经存在的文件,那么该文件将会从读写层下面的只读层复制到读写层,该文件的只读版本依然存在,只是已经被读写层中该文件…

PyTorch中卷积层torch.nn.Conv2d

在 PyTorch 中&#xff0c;卷积层主要由 torch.nn.Conv1d、torch.nn.Conv2d 和 torch.nn.Conv3d 实现&#xff0c;分别对应一维、二维和三维卷积操作。以下是详细说明&#xff1a; 1. 二维卷积 (Conv2d) - 最常用 import torch.nn as nn# 基本参数 conv nn.Conv2d(in_channe…

从 ZStack 获取物理机与云主机信息并导出 Excel 文件

文章目录 从 ZStack 获取物理机与云主机信息并导出 Excel 文件环境zstack 官网客户端封装讲解 获取物理机信息讲解 获取云主机信息并关联物理机讲解 导出数据到 Excel 文件讲解 运行主程序讲解 总结最终文档效果完整代码 从 ZStack 获取物理机与云主机信息并导出 Excel 文件 在…

5.好事多磨 -- TCP网络连接Ⅱ

前言 第4章节通过回声服务示例讲解了TCP服务器端/客户端的实现方法。但这仅是从编程角度的学习&#xff0c;我们尚未详细讨论TCP的工作原理。因此&#xff0c;将详细讲解TCP中必要的理论知识&#xff0c;还将给出第4章节客户端问题的解决方案。 一、回声客户端完美实现 第4章…