【C++】STL简介

在这里插入图片描述

🔥个人主页: Forcible Bug Maker
🔥专栏:STL || C++

目录

  • 前言
  • 什么是STL?
  • STL的历史
  • STL的版本
  • STL六大组件
  • STL的优缺点
    • STL的优点:
    • STL的缺点:
  • 如何学习STL
  • 结语

前言

本篇博客主要内容:STL简介

开始学习STL之前,是不是得先知道STL是个什么东西,以及如何学习STL呢?话不多说,开始我们今天的内容!

什么是STL?

STL(standard template libaray-标准模板库):是C++标准库的重要组成部分,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架

STL的历史

STL(Standard Template Library,标准模板库)的起源可以追溯到C++语言的早期发展阶段。STL的设计和创建主要归功于Alexander Stepanov,他在1980年代开始研究泛型编程和数据结构

Alexander Stepanov最初在惠普公司(HP)工作期间,对泛型编程和算法进行了深入研究。他意识到,在C++中,由于缺乏标准的数据结构和算法库,程序员经常需要重复编写相同的代码,这导致了代码的冗余和低效。为了解决这个问题,Stepanov开始设计一种基于模板的库,该库能够提供通用、高效的数据结构和算法,同时保持灵活性和可扩展性

1994年,Stepanov首次公开发表了STL的概念和设计。 STL最初是基于Silicon Graphics(SGI)的STL版本开发的,这个版本被称为SGI-STL。SGI-STL的发布引起了广泛的关注,并被许多厂商和开源社区所采用和扩展

随着STL的发展,越来越多的开发者开始意识到它的价值,并加入到STL的开发和贡献中。在1995年,C++标准委员会推荐将STL作为C++标准库的一部分,这标志着STL正式成为了C++语言的一部分

1998年,C++标准库正式发布,STL被正式纳入其中。 此后,STL随着C++标准的不断发展而不断完善和扩展。在C++11、C++14、C++17等后续标准中,STL引入了更多的新特性和数据结构,如unordered_map、unordered_set、array等,进一步提高了STL的实用性和效率

STL的创建和发展是一个由多位专家和开发者共同努力的过程。它不仅是C++标准库的重要组成部分,也是C++编程中不可或缺的工具之一。

STL的版本

版本内容
原始版本Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本,本着开源精神,他们声明允许任何人任意运用、拷贝、修改、传播、商业使用这些代码,无需付费。唯一的条件就是也需要向原始版本一样做开源使用。 HP 版本–所有STL实现版本的始祖
P.J.版本由P. J. Plauger开发,继承自HP版本,被Windows Visual C++采用,不能公开或修改,缺陷:可读性比较低,符号命名比较怪异
RW版本由Rouge Wage公司开发,继承自HP版本,被C+ + Builder 采用,不能公开或修改,可读性一般。
SGI版本由Silicon Graphics Computer Systems,Inc公司开发,继承自HP版 本。被GCC(Linux)采用,可移植性好,可公开、修改甚至贩卖,从命名风格和编程 风格上看,阅读性非常高。我们后面学习STL要阅读部分源代码,主要参考的就是这个版本

目前主流的两个版本,一个是微软的P.J.版本,至今一直由微软的工程师开发维护中;另一个就是被GCC(Libux)采用的SGI版本。只有不断迭代和优化的版本,才能始终在大众的视野中,并被广泛的使用和传播。

STL六大组件

  1. 容器(Containers)
    容器是STL中用于存储和管理数据的组件。它们提供了各种数据结构,如向量(vector)、列表(list)、双端队列(deque)、集合(set)、映射(map)等。
    这些容器封装了数据的存储方式,并提供了一系列成员函数来访问和操作数据。
  2. 迭代器(Iterators)
    迭代器是STL中用于遍历容器元素的工具。它们提供了一种通用的方式来访问容器中的元素,而无需关心容器底层的实现细节。
    STL中的迭代器分为五种类型:输入迭代器、输出迭代器、前向迭代器、双向迭代器和随机访问迭代器。不同类型的迭代器提供了不同的操作功能。
  3. 算法(Algorithms)
    STL中的算法库提供了一系列常见的数据处理算法,如排序(sort)、查找(find)、遍历(traverse)、修改(modify)、复制(copy)、合并(merge)、反转(reverse)、旋转(rotate)等。这些算法可以与STL容器一起使用,以实现各种复杂的数据处理任务。
  4. 仿函数(Functors)
    仿函数也称为函数对象,是一种特殊的类,其行为类似于函数。它们通过重载函数调用运算符operator()来定义自己的行为。
    仿函数可以作为算法的某种策略,用于定制算法的行为。STL中的许多算法都接受仿函数作为参数,以实现更灵活的数据处理。
  5. 配接器(Adapters)
    配接器是一种将容器或仿函数转换成其他类型或接口的工具。它们提供了一种将现有组件组合起来以创建新组件的方法。
    STL中的配接器包括容器配接器(如栈stack、队列queue和优先级队列priority_queue)和迭代配接器(如反向迭代器)。这些配接器可以扩展STL组件的功能和用途。
  6. 分配器(Allocators)
    分配器用于管理容器所使用的内存。它们提供了内存分配、回收和管理的方法,以实现高效的内存使用。
    STL中的分配器是一个可配置的组件,可以根据需要选择不同的分配策略。这有助于优化程序的性能和内存使用。

在这里插入图片描述

C++ STL的六大组件为程序员提供了强大的工具集,可以高效地实现各种复杂的数据结构和算法。这些组件的灵活性和可复用性使得C++成为了一种高效、可靠且易于维护的编程语言。

STL的优缺点

STL作为C++标准库的一个重要组成部分,提供了大量通用的数据结构、算法和函数对象,极大地提高了C++编程的效率和可重用性。然而,STL也有其优点和缺点。

STL的优点:

  • 高效性:STL中的数据结构和算法经过精心设计和优化,能够在各种场景下提供高效的性能。例如,vector、list、map等容器都采用了高效的内存管理策略,而sort、find等算法也使用了优化的算法实现。

  • 通用性:STL使用了模板技术,支持泛型编程,因此可以处理各种类型的数据,而不仅仅是内置类型。这使得STL的代码具有高度的可重用性。

  • 易用性:STL提供了简洁、一致的接口,使得使用STL的代码更加清晰、易读。同时,STL也遵循了C++的标准库规范,使得学习STL变得更加容易。

  • 可扩展性:STL允许用户自定义数据类型和算法,通过适配器(adapters)和仿函数(functors)等技术,可以轻松地将自定义的数据类型和算法与STL库中的组件集成起来。

  • 安全性:STL库中的许多容器和算法都提供了对异常和错误的处理机制,例如,在容器越界访问时抛出异常等。这有助于减少程序中的错误和安全隐患。

STL的缺点:

  • 性能开销:虽然STL中的许多数据结构和算法都经过了优化,但在某些情况下,使用STL可能会导致一些额外的性能开销。例如,STL中的动态内存分配和释放可能会比使用静态内存或堆外内存更加耗时。

  • 学习曲线:STL的接口和用法相对复杂,需要一定的学习和实践才能熟练掌握。特别是对于初学者来说,学习STL可能会比较困难。

  • 内存管理:虽然STL提供了许多方便的容器和算法,但它们在内存管理方面仍然存在一些限制。例如,STL中的容器通常不会自动回收不再使用的内存,这可能会导致内存泄漏问题。此外,STL中的动态内存分配也可能会导致内存碎片问题。

  • 非标准扩展:虽然STL是C++标准库的一部分,但不同的编译器和平台可能会提供不同的STL实现和扩展。这可能会导致跨平台兼容性问题和代码移植问题。

总结一下:STL确实提供了高效、通用、易用、可扩展和安全的数据结构和算法,极大提升了C++编程的效率和可重用性;但在某些情况下可能引入性能开销,具有陡峭的学习曲线,内存管理需要谨慎处理,存在非标准扩展可能导致的兼容性问题。STL是把双刃剑,当你在正真了解STL之后,才能真正体会到这句话的含义。

如何学习STL

STL是打各种算法比赛以及开发过程中必不可少得一个工具,学习STL可以分为四步,首先是了解其底层得数据结构,其次学习其用法,然后尝试深入理解其底层实现,最后需要通过大量习题和项目的练习加强理解。
在这几个阶段的过程中,你可以参考官方文档以及各种书籍,比如:C++官方文档:https://zh.cppreference.com,不过这个网站网速较慢,而且内容比较杂乱;这里推荐参考这个网站,https://cplusplus.com,它虽然不是官网,但是里面的C++STL的内容整理的非常清晰,唯一的缺点就是全英文。在学习和实践STL源码的过程中,可以参考侯捷老师的源码剖析:
在这里插入图片描述
刷题的话,各大刷题网站都会有对应的题目,博主其实也有出一些相关练习及题解的想法。
力扣
codeforces
洛谷

结语

本篇博客主要介绍了有关STL的历史,主流版本,六大组件,以及其优缺点和学习方法等内容。希望能帮助到大家。博主后续会持续更新更多有关于STL的内容,感谢大家的支持!♥

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

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

相关文章

灾备技术演进之路 | 虚拟化无代理备份只能挂载验证和容灾吗?只能无代理恢复吗?且看科力锐升级方案

灾备技术演进之路系列 虚拟化备份技术演进 摆脱束缚,加速前行 无代理备份仅能挂载/恢复验证吗? ——科力锐极简验证演练无代理备份来了 无代理备份无法应对平台级故障吗? ——科力锐应急接管无代理备份来了 无代理备份仅能同平台挂载吗&a…

Llama 3.1 Omni:颠覆性的文本与语音双输出模型

你可能听说过不少关于语言模型的进展,但如果告诉你,有一种模型不仅能生成文本,还能同时生成语音,你会不会觉得特别酷?今天咱们就来聊聊一个相当前沿的项目——Llama 3.1 Omni模型。这个模型打破了传统的文字生成边界,直接让文本和语音同时输出,实现了真正的"多模态…

无人机之AI跟踪篇

无人机的AI识别技术依托于计算机视觉和深度学习技术,实现了对目标的快速精准识别,在多个领域展现出了巨大的应用潜力和价值。以下是对无人机AI识别技术的详细解析: 一、无人机AI识别算法的基础原理 无人机AI识别算法主要基于先进的计算机视觉…

轻松解决Jetpack Compose中的一些痛点问题

公众号「稀有猿诉」 原文链接 轻松解决Jetpack Compose中的一些痛点问题 暑去秋来,金桂飘香,不知不觉中我们已经练完了『降Compose十八掌』,相信通过这一系列文章能够对Jetpack Compose有足够的理解,并能在实际项目中进行运…

Linux memcg lru lock提升锁性能

目录 内核关于per memcg lru lock的重要提交: 计算虚拟地址转换基本机制 问题背景 swap换入流程 时奎亮的per memcg lru lock分享视频 内核关于per memcg lru lock的重要提交: f9b1038ebccad354256cf84749cbc321b5347497 6168d0da2b479ce25a4647d…

感知笔记:ROS 视觉- 跟随红球

- 目录 - 如何在 ROS 中可视化 RGB 相机。如何作为机器人切换主题。如何创建 blob 检测器。如何获取要跟踪的颜色的颜色编码。如何使用 blob 检测数据并移动 RGB 相机以跟踪 blob。 机器人技术中最常见的传感器是不起眼的 RGB 摄像头。它用于从基本颜色跟踪(blob 跟…

ssm自助购药小程序 LW PPT源码调试讲解

第二章开发技术介绍 此系统的关键技术和架构,Java技术、B/S结构、Ssm框架和Mysql数据库,是本系统的关键开发技术,对系统的整体、数据库、功能模块、系统页面以及系统程序等设计进行了详细的研究与规划。 2.1 系统开发平台 在线自助购药小程…

PMP--二模--解题--1-10

文章目录 4.整合管理--商业文件--商业论证(是否值得所需投资、高管们决策的依据)反映了:1、 [单选] 收到新项目的客户请求之后,项目经理首先应该做什么? 14.敏捷--角色--产品负责人PO–职责–1.创建待办列表并排序;2.确…

大数据概念与价值

文章目录 引言大数据的概念高德纳咨询公司的定义麦肯锡全球研究所的定义什么是大数据? 大数据的特征Volume(体积)Variety(种类)Velocity(速度)Value(价值)Veracity&#…

计算机毕业设计Python+Flask微博情感分析 微博舆情预测 微博爬虫 微博大数据 舆情分析系统 大数据毕业设计 NLP文本分类 机器学习 深度学习 AI

首先安装需要的python库, 安装完之后利用navicat导入数据库文件bili100.sql到mysql中, 再在pycharm编译器中连接mysql数据库,并在设置文件中将密码修改成你的数据库密码。最后运行app.py,打开链接,即可运行。 B站爬虫数…

恢复已删除文件的可行方法,如何恢复已删除的文件

在清理 PC 或优化存储设备时无意中删除重要文件是一种常见的人为错误。不可否认,在批量删除文件时,您通常会一起删除垃圾文件和重要文件。您后来意识到一堆文件或文件中缺少一个重要的文档或文件。在这种情况下,您唯一的选择是寻找恢复已删除…

打点-heapdump信息泄露-shiro反序列化获得root权限shell

fscan 扫描结果 heapdump 下载 使用 JDumpSpider-1.1-SNAPSHOT-full.jar 分析,获取 shiro 密钥 验证 爆破利用链 命令执行

【小鹏汽车用户平台-注册安全分析报告-无验证方式导致安全隐患】

前言 由于网站注册入口容易被黑客攻击,存在如下安全问题: 1. 暴力破解密码,造成用户信息泄露 2. 短信盗刷的安全问题,影响业务及导致用户投诉 3. 带来经济损失,尤其是后付费客户,风险巨大,造…

iotop 命令:磁盘IO监控和诊断

一、命令简介 ​iotop​命令用于监视磁盘I/O,实时显示每个进程或线程的读写速率等信息。非常适合用于诊断系统中的I/O瓶颈。 ‍ ​​ ‍ 安装 iotop 在大多数Linux发行版中,iotop​可能不是预装的。可以使用包管理器来安装它。 例如,在…

uniapp出现 下拉框等组件被遮挡 的分析

目录 1. 问题所示2. 代码复现3. 解决方法3.1 下拉框被遮挡3.2 uni-collapse-item 无法下拉的问题 1. 问题所示 下拉框被遮挡的问题&#xff1a; uni-collapse-item组件无法下拉的问题&#xff1a; 2. 代码复现 博主的代码精简如下&#xff1a; <template><view>…

K-means 算法的介绍与应用

目录 引言 K-means 算法的基本原理 表格总结&#xff1a;K-means 算法的主要步骤 K-means 算法的 MATLAB 实现 优化方法与改进 K-means 算法的应用领域 表格总结&#xff1a;K-means 算法的主要应用领域 结论 引言 K-means 算法是一种经典的基于距离的聚类算法&#xff…

微信支付 02 加深理解密钥,加密解密,数字签名,数字证书

1.0 1.1 公钥&#xff08;Public Key&#xff09; 定义&#xff1a; 公钥是在非对称加密系统中使用的一个密钥&#xff0c;可以安全地公开和广泛分发。功能&#xff1a; 主要用于加密数据和验证数字签名。在加密过程中&#xff0c;公钥用于加密信息&#xff0c;只有对应的私钥…

计算机网络:概述 --- 体系结构

目录 一. 体系结构总览 1.1 OSI七层协议体系结构 1.2 TCP/IP四层(或五层)模型结构 二. 数据传输过程 2.1 同网段传输 2.2 跨网段传输 三. 体系结构相关概念 3.1 实体 3.2 协议 3.3 服务 这里我们专门来讲一下计算机网络中的体系结构。其实我们之前…

.NET常见的几种项目架构模式,你知道几种?(附带使用情况投票)

前言 项目架构模式在软件开发中扮演着至关重要的角色&#xff0c;它们为开发者提供了一套组织和管理代码的指导原则&#xff0c;以提高软件的可维护性、可扩展性、可重用性和可测试性。 假如你有其他的项目架构模式推荐&#xff0c;欢迎在文末留言&#x1f91e;&#xff01;&a…

道路红外目标检测数据集 6500张 带标注 voc yolo

道路红外目标检测数据集 6500张 带标注 voc yolo 道路红外目标检测数据集 数据集描述 该数据集旨在用于道路环境中的红外目标检测任务&#xff0c;涵盖了多种场景下的红外图像。数据集包含大量的图像及其对应的标注信息&#xff0c;可用于训练计算机视觉模型&#xff0c;以识…