【C++】了解一下STL

个人主页 : zxctscl
如有转载请先通知

STL

  • 1. 什么是STL
  • 2. STL的版本
  • 3. STL的六大组件
  • 4. STL的重要性
  • 5. 如何学习STL
  • 6. STL的缺陷

1. 什么是STL

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

STL是C++标准库的一部分,像之前的iostream也是标椎库的一部分,不能任务STL里面包含iostream。它们的关系是同级的。
在这里插入图片描述

2. STL的版本

  1. 原始版本
    Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本,本着开源精神,他们声明允许任何人任意运用、拷贝、修改、传播、商业使用这些代码,无需付费。唯一的条件就是也需要向原始版本一样做开源使用。 HP 版本–所有STL实现版本的始祖。

  2. P. J. 版本
    由P. J. Plauger开发,继承自HP版本,被Windows Visual C++采用,不能公开或修改,缺陷:可读性比较低,符号命名比较怪异。

  3. RW版本
    由Rouge Wage公司开发,继承自HP版本,被C+ + Builder 采用,不能公开或修改,可读性一般。

  4. SGI版本
    由Silicon Graphics Computer Systems,Inc公司开发,继承自HP版 本。被GCC(Linux)采用,可移植性好,可公开、修改甚至贩卖,从命名风格和编程 风格上看,阅读性非常高。在后面学习STL要阅读部分源代码,主要参考的就是这个版本

3. STL的六大组件

在这里插入图片描述
STL包含六大组件,分别是:

  1. 容器(Containers):容器是STL中最重要的组件之一。它提供了各种数据结构(如数组、链表、堆、映射等),用于存储和组织数据。常用的容器包括vector、list、deque、set、map等。

  2. 算法(Algorithms):算法是STL的核心组件之一,提供了一系列的常用算法,如排序、查找、合并、拷贝等。开发者可以直接调用这些算法,在容器上进行各种操作。

  3. 迭代器(Iterators):迭代器是STL中非常重要的概念,用于遍历容器中的元素。迭代器提供了一种统一的方式来访问和操作容器中的元素,使得算法可以独立于具体容器的实现。

  4. 配接器(Adapters):适配器是STL中用于扩展和修改容器或算法功能的组件。STL提供了多种适配器,如stack、queue、priority_queue等,可以通过适配器将容器或算法的接口进行转换,以满足特定的需求。

  5. 空间配置器(Allocators):分配器是STL中用于内存管理的组件。STL的容器在内部使用分配器来动态分配和释放内存,开发者可以通过自定义分配器,对内存分配进行优化或扩展。

  6. 仿函数(Functors):仿函数是STL中用于封装函数对象的组件。STL的算法中经常需要接受一个函数对象作为参数,用于指定具体的操作。仿函数实际上是一种重载了函数调用操作符的类,可以像函数一样调用。

总的来说,STL的六大组件提供了一套完整的工具箱,可以帮助开发者快速地实现各种常用的数据结构和算法,提高开发效率和代码的可重用性。

4. STL的重要性

在一些笔试题目里面就有,就像下面这题:
用C语言代码可能是c++代码的两倍,
在这里插入图片描述
在面试里面也有相关的题目:
在这里插入图片描述

网上有句话说:“不懂STL,不要说你会C++”。STL是C++中的优秀作品,有了它的陪伴,许多底层的数据结构以及算法都不需要自己重新造轮子,站在前人的肩膀上,健步如飞的快速开发。

5. 如何学习STL

在这里插入图片描述
在这里插入图片描述

简单总结一下:学习STL的三个境界:1. 使用,2. 明理,3. 扩展 。
前面两个走好了才能走第三个。

6. STL的缺陷

  1. STL库的更新太慢了。这个得严重吐槽,上一版靠谱是C++98,中间的C++03基本一些修订。C++11出来已经相隔了13年,STL才进一步更新。
  2. STL现在都没有支持线程安全。并发环境下需要我们自己加锁。且锁的粒度是比较大的。
  3. STL极度的追求效率,导致内部比较复杂。比如类型萃取,迭代器萃取。
  4. STL的使用会有代码膨胀的问题,比如使用vector/vector/vector这样会生成多份代码,当然这是模板语法本身导致的。

有问题请指出,大家一起进步吧!!!

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

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

相关文章

最迟但到的 Star History 2023 年度开源精选!

千呼万唤始出来,Star History 2023 年终开源精选来啦!🎉 AI 是 2023 开源领域里最主要的关键词,但其实过去一年还是有很多其他值得关注的项目和发展趋势的!Star History 小编总结了几个类别并精选了类别中最亮眼的项目…

MT6771 android13 自定义背光曲线

一. Android系统源码中的参数配置 MTK6771平台MTK重写了背光曲线的参数,路径在s0_vnd/vendor/mediatek/proprietary/packages/overlay/vendor/FrameworkResOverlayExt/brightness_adaptive_support/res/values/config.xml 不过MTK的其他平台可能不是在这个路径 来看…

学习Java的第六天

目录 一、变量 1、变量的定义 2、变量的声明格式 3、变量的注意事项 4、变量的作用域 二、常量 三、命名规范 Java 语言支持如下运算符: 1、算术运算符 解析图: 示例: 2、赋值运算符 解析图: 示例: 3、关…

#微信小程序创建(获取onenet平台数据)

1.IDE:微信开发者工具 2.实验:创建一个小程序(http get获取onenet平台数据) 3.记录: 百度网盘链接:https://pan.baidu.com/s/1eOd-2EnilnhPWoGUMj0fzw 提取码: 2023 (1)新建一个工…

基于FPGA加速的bird-oid object算法实现

导语 今天继续康奈尔大学FPGA 课程ECE 5760的典型案例分享——基于FPGA加速的bird-oid object算法实现。 (更多其他案例请参考网站: Final Projects ECE 5760) 1. 项目概述 项目网址 ECE 5760 Final Project 模型说明 Bird-oid object …

Linux安全--为Nginx加上PHP解析功能

yum install php-fpm -y安装php进程管理器 找到Nginx安装的路径 编辑Nginx配置文件

短视频,文案素材哪里找?找短视频文案素材指南

有很多创业者,耗费了很长时间创作出了很多短视频,文案素材没写好,导致浏览量下降,或者写文案的同时就已经花费了很长时间,导致没有时间发布视频,从而影响了流量,导致流量下滑,其实我…

STM32CubeMX学习笔记18——FSMC(TFT-LCD屏触摸)

1.触摸屏简介 目前最常用的触摸屏有两种:电阻式触摸屏和电容式触摸屏 1.1 电阻式触摸屏 电阻式的触摸屏结构如下图示,它主要由表面硬涂层、两个ITO层、间隔点以及玻璃底层构成,这些结构层都是透明的,整个触摸屏覆盖在液晶面板上…

如何轻松打造属于自己的水印相机小程序?

水印相机小程序源码 描述:微信小程序。本文将为您详细介绍小程序水印相机源码的搭建过程,教您如何轻松打造属于自己的水印相机小程序。无论您是初学者还是有一定基础的开发者,都能轻松掌握这个教程。 一:水印相机搭建教程 1 隐…

Linux:kubernetes(k8s)Deployment的操作(12)

创建deployment 命令 kubectl create deploy nginx-deploy --imagenginx:1.7.9 再去使用以下命令分别查询 ubectl get deploy kubectl get replicaset kubectl get pod 他是一个层层嵌套的一个关系 首先是创建了一个 deploy 里面包含着replicaset replicaset里面含有…

ChatGPT等AI使用的过程苦笑不得瞬间

引言: 在人工智能的浪潮中,我们见证了技术的飞速发展和智能应用的广泛渗透。特别是随着语言模型的进步,AI如ChatGPT、文心一言、通义千问、讯飞星火等已经成为人们日常生活和工作中不可或缺的助手。然而,与任何新兴技术一样&#…

025—pandas 根多列判断不在其他列的数据

思路 是有两个相同结构的数据表,已知第二个表是第一个表的部分数据,需要以其中两列为单位,判断在第一个表中存在,在另外一个表中不存在的数据。 思路: 我们先将 df1 和 df2 的 x、y 列取出,组合为元组形成…