C++模板——(4)C++泛型编程与标准模板库简介

归纳编程学习的感悟,
记录奋斗路上的点滴,
希望能帮到一样刻苦的你!
如有不足欢迎指正!
共同学习交流!
🌎欢迎各位→点赞 👍+ 收藏⭐ + 留言​📝
勤奋,机会,乐观是成功的三要素!

一起加油!

目录

一、前言:

二、STL概述: 

三、容器: 

1、向量:

2列表:

3、集合: 

4、双端队列:

5、栈:

6.映射: 

例:使用向量,将字符串传送到字符向量中并显示。 

四、算法:  

五、选代器:

六、共勉: 


一、前言:

        标准模板库(Standard Template Library,STL)是一个高效、实用的 C++程序库。它被容纳于 C++标准程序库中,是ANSI/ISO C++标准中最新的,也是极具革命性的一部分。该库包含了诸多计算机科学领域里常用的基本数据结构和基本算法,为广大 C++程序员们提供了一个可扩展的应用框架,高度体现了软件的可复用性。

二、STL概述: 

        STL在C++程序设计中的作用是提供一个可供函数调用的组件和函数库,当需要时通过接口来调用,STL 的目的是标准化组件,用户不用重新开发它们,就可以使用这些现成的组件。STL
现在是 C++的一部分,被内建在编译器之内。

        虽然STL是一个模板库,但其中也包含了许多部分。一般来说,STL由如下六个部分组成。

(1)容器(Containers):用于管理数据集合,包括各种数据结构,比如vector、list、deque、set、map用来存放数据
        从实现的角度来看,STL容器是一种类模板。
(2)算法(Algorithms):定义了计算过程,其包括各种算法,比如sort、search、copy、erase 等
        从实现的角度来看,STL算法是一种函数模板。
(3)选代器(Iterators):提供了遍历容器的方法它扮演了容器与算法之间的胶合剂、即“泛型指针”。共有5种类型及其他衍生变化。
        从实现角度来讲,STL迭代器是一种将operator*、operator->、operator++、operator--等指针相关操作予以重载的类模板。所有的 STL容器都附有自己专属的迭代器。
(4)仿函数(Functors)将函数封装在对象中,供其他组件使用。行为类似函数,可作为算法的某种策略。

        从实现角度来看,它是一种重载了 operator()的类或者类模板,一般的函数指针可被视为狭义的仿函数。
(5)配接器(Adapters):一种用来修饰容器、仿函数或迭代器的接口,如STL提供的queue和stack,虽然看似容器,其实只能算一种容器配接器,因为它们底部完全借助 deque,所有操作都有底层的 deque 供应。改变functor 接口的被称为function adapter,改变container 接口的被称为container adapter。
(6)配置器(Allocators):负责空间配置与管理。
        从实现角度来看,配置器是一个实现了动态空间配置、空间管理、空间释放的类模板。

        STL的代码从广义上来讲可分为三类:容器(Containers)、算法(AIgorithms)、选代器(Iterators)。几乎所有的代码都采用了模板类和模板函数的方式,这相比于传统的由函数和类成的库来说提供了更好的代码重用机会。

        在C++标准中,STL 被组织为下面的13 个头文件:<algorithms>、<deque>、<functiona>、<iterator>、<vector> 、<list>、<map>、<memory>、<numeric>、<queue>、<set> 、<stack>和<utility> 

三、容器: 

        STL容器允许重复利用已有的实现构造自己特定类型下的数据结构,通过设置一些模板类这些模板的参数允许用户指定容器中元素的数据类型,从而可以提高编程效率。
        容器部分主要由头文件<deque>、<vector>、<list>、<map>、<queue>、<set>、<stack>组成。  

1、向量:

        需在头文件加入:#include<vector>。
        向量是一种 vector 容器类,向量就像是盛放变长数组的容器,大约所有 STL容器中有一般是基于向量的。vector 是一种动态数组,是基本数组的类模板。其内部定义了很多基本操作。vector类中定义了四种构造函数。
(1)默认构造函数:其构造了一个初始长度为0的向量,其调用方式如下        
vector<int>   vl;
(2)带有单个整型参数的构造函数:此参数描述了向量的初始大小,该构造函数还有一个可选的参数,这是一个类型为T的实例,描述了各个向量中各成员的初始值,其调用方式如下:
vector<int>  v2(init_size,0);//如果预先定义了init_size其成员值都初始化为0

(3)复制构造函数构造一个新的向量,作为已存在的向量的完全复制,其调用方式如下
vector<int> v3(v2);

(4)含有两个常量参数的构造函数:产生初始值为一个区间的向量。区间由一个半开区间[first,last]来指定,其调用方式如下:
vector<int> v4(first,last);

        此外,在实际程序中使用较多的还是向量类的成员函数,其常用的成员函数包括:

        begin()、end()、push_back()、insert()、assign()、 front()、 back()、 erase()、 empty()、 at()、 size()。

2列表:

        需在头文件加入:#include<list>
        列表也是容器类的一种,其控制的长度为N的序列是以一个有着N个节点的双向链表来存储的,支持双向迭代器。使用列表的有时是可以在链表中插入和删除的元素或者子链表,只需改变前后指针就可实现。

        列表类的定义如下:

        typedef list<T>,allocator<T>  mycont;        //使用默认模板参数,可以省略第二个参数

其成员函数及作用如下所示
resize:被控序列的长度改为只容纳n个元素,超出元素被删除。
clear:删除所有元素。

front,back:存取被控序列的第一个元素,存取被控序列的最后一个元素。

push_back:向对象末端插人值为x的元素。push_front为对象开始处插入元素;pop_back为删除最后一个元素;pop_front 为删除第一个元素。
assign:为了将被控序列替换成由(first,last)所指定的序列。

insert:为了在迭代器it指定的元u素前插入一个元素。 

erase:删除it所指定的元素。  

splice:将一系列的列表节点接入到一个列表中。

remove:删除所有值等于v的元素。

sort:将序列排序。 

merge:将两个有序排序序列合并。

reverse:翻转整个序列。

3、集合: 

        需在头文件加入:#include<set>
        集合也是容器的一种,它的特点是集合中的元素值是唯一的。在集合中,所有的成员都是排列好的。如果先后往一个集合插入:23、12、0、42、123,则输出该集合时为:0、12、23、42、123。

4、双端队列:

        需在头文件加入:#include<deque>
        双端队列是一个queue容器类(队列容器),与vector类似,支持随机访问和快速插入删除它在容器中某一位置上的操作所花费的线性时间与vector。不同的是,deque 还支持从开始端插入数据,因为其包含在开始端插入数据的函数push_front()。

5、栈:

        需在头文件加入:#include<stack>

        容器栈是一种特殊的容器,其特征是后进先出,即先进来的元素放在栈底,最后才能取出。栈容器支持的操作有如下五种:

  • empty:如果栈为空,返回true; 否则返回false。
  • size:返回栈中元素的个数。
  • pop:删除,但不返回栈顶元素。
  • top:返回,但不删除栈顶元素。
  • push:放人新的栈顶元素。

6.映射: 

        需在头文件加入:#include<map>

        映射用于对数据进行快速和高效的检索。

例:使用向量,将字符串传送到字符向量中并显示。 

#include<vector>			//STL向量头文件 
#include<iostream>
using namespace std;
char *s="Hello world";		//定义字符数组 
int main()
{vector<char> vec;		//声明一个字符向量vector vector<char>::iterator vi;//为字符数组定义一个字符游标iterators char *p=s;			 	//定义指针指向字符串 while(*p!='\0')			//初识化字符向量,把数据填充到字符向量中 {vec.push_back(*p);	//puch_back函数,把数据放在向量的尾部 p++;} for(vi=vec.begin();vi!=vec.end();vi++){cout<<*vi;			//将向量中的数据一一显示出来 }cout<<endl;return 0;
}

四、算法:  

         算法是STL的重要组成部分。STL 提供了大约 100个实现算法的模板函数,用户可以通过调用算法模板完成所需的功能,这样大大地提高了用户使用C++进行程序设计的效率。

        一般来说,STL中的算法部分主要由头文件<algorithms>、<numeric>、<functional>组成。其中头文件<algorithms>由模板函数组成,常见的函数涉及比较、交换、查找、排序等。

五、选代器:

        迭代器实际上是一种泛化指针,如果一个迭代器指向了容器中的某一成员,那么迭代器将可以通过自增和自减来遍历容器中的所有成员。迭代器是联系容器和算法的媒介,是算法操作容器的接口。

        简单来说,STL提供的所有算法几乎都是通过迭代器存取元素序列进行工作的,每一个容器都定义了它本身所专有的迭代器,用以存取容器中的元素。在前面运用算法操作容器时,就在不知不觉中使用了迭代器。
        STL中的选代器主要由头文件<utility>、<iterator>、<memory>组成。其中,<utility>包括了贯穿使用在 STL中的几个模板的声明,<iteratot>头文件中提供了迭代器使用的许多方法。<memory>头文件中的主要部分是模板类 allocator,它负责产生所有容器中的默认分配器。

六、共勉: 

        以上就是我对C++模板——(4)C++泛型编程与标准模板库简介的理解,希望本篇文章对你有所帮助,也希望可以支持支持博主,后续博主也会定期更新学习记录,记录学习过程中的点点滴滴。如果有不懂和发现问题的小伙伴,请在评论区说出来哦,同时我还会继续更新对C++模板的理解,请持续关注我哦!!! 

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

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

相关文章

海量数据处理数据结构之Hash与布隆过滤器

前言 随着网络和大数据时代的到来&#xff0c;我们如何从海量的数据中找到我们需要的数据就成为计算机技术中不可获取的一门技术&#xff0c;特别是近年来抖音&#xff0c;快手等热门短视频的兴起&#xff0c;我们如何设计算法来从大量的视频中获取当前最热门的视频信息呢&…

Vue3:使用解构赋值来读取对象里的键-值对(值也是对象)

一、前言 在Vue3中&#xff0c;想要读取一个对象的“键—值”对&#xff08;值也是一个对象&#xff09;&#xff0c;数据格式如下&#xff1a; {1:{courseName: 课程1, study: 951526, visit: 3785553}&#xff0c;2:{courseName: 课程2, study: 181630, visit: 380830}&…

VCG 网格曲率计算

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 Mesh曲率特征通常指的是在三维几何网格(Mesh)上计算的曲率相关的一系列特征,包括主曲率、高斯曲率、平均曲率等。这些曲率特征提供了对Mesh表面形状的详细描述,对于表面形状分析、形状比较和几何建模等领域非常…

【UML】第16篇 活动图

目录 一、什么是活动图 二、应用场景&#xff1a; 三、绘图符号的说明&#xff1a; 四、语法&#xff1a; 五、例图 六、建模的流程 6.1 对业务流程建模时 6.2 对用例进行活动图建模时 一、什么是活动图 活动图&#xff08;Activity Diagram&#xff09;是UML中用于描…

msckf-vio 跑Euroc数据集,并用evo进行评估

所需材料&#xff1a; Euroc数据集主页&#xff1a;https://projects.asl.ethz.ch/datasets/doku.php?idkmavvisualinertialdatasetsevo评估工具代码&#xff1a;https://github.com/MichaelGrupp/evo向msckf-vio中添加保存位姿的代码&#xff0c;可参考https://blog.csdn.ne…

网络安全复习--简答整理

-----------------------------------------------------教材如上图------------------------------------------------------------ 1.对称加密和非对称加密各有什么特点&#xff1f;加密解密过程中有什么区别&#xff1f;优点P38【考】 对称加密的特点&#xff1a;在针对同一…

JDBC多表联查

JDBC多表联查 在单一表进行查询时&#xff0c;只需要对表中的单个字段进行解析即可&#xff1b;例如下面代码&#xff1a; Overridepublic List<ClassBean> selectAllDao() {List list new ArrayList();try {String sql "select * from class";rs select(s…

Spring MVC 参数接收

参数接收 Springmvc中&#xff0c;接收页面提交的数据是通过方法形参来接收&#xff1a; 处理器适配器调用springmvc使用反射将前端提交的参数传递给controller方法的形参 springmvc接收的参数都是String类型&#xff0c;所以spirngmvc提供了很多converter&#xff08;转换器…

网络名称解读 -入门5

WAN: Wide Area Network(跨区域&#xff09;&#xff0c;LAN&#xff1a; Local Area NetworkWAN MAC&#xff0c; 用来连接上级网络&#xff0c; LAN MAC&#xff0c; 用于内部网路。 LAN & WAN 3.1&#xff0c;LAN表示子网&#xff0c;通过掩码来筛选子网内主机数量&…

Unity Delaunay三角剖分算法 动态生成

Unity Delaunay三角剖分算法 动态生成 Delaunay三角剖分Delaunay三角剖分 定义Delaunay 边Delaunay 空圆特性 Delaunay 三角形Delaunay 最大化最小角特性 Delaunay 三角形特征Delaunay 算法Delaunay Lawson算法Delaunay Bowyer-Watson算法 Unity Delaunay三角剖分 应用Unity 工…

Vulnhub-VULNCMS: 1渗透

文章目录 一、前言1、靶机ip配置2、渗透目标3、渗透概括 开始实战一、信息获取二、获取shell三、获取密码文件四、提权 一、前言 由于在做靶机的时候&#xff0c;涉及到的渗透思路是非常的广泛&#xff0c;所以在写文章的时候都是挑重点来写&#xff0c;尽量的不饶弯路。具体有…

uniapp微信小程序投票系统实战 (SpringBoot2+vue3.2+element plus ) -后端鉴权拦截器实现

锋哥原创的uniapp微信小程序投票系统实战&#xff1a; uniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )_哔哩哔哩_bilibiliuniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )共计21条视频…

邻接矩阵、可达性矩阵、完全关联矩阵、可达性矩阵的计算

邻接矩阵&#xff1a;很简单&#xff0c;就是两个点有关系就是1&#xff0c;没有关系就是0 可达性矩阵&#xff1a;非常简单&#xff0c;两点之间有路为1&#xff0c;没有路为0 可发行矩阵的计算&#xff1a;有n个元素&#xff0c;初始可达性矩阵为A&#xff0c;那么最终的矩阵…

K2P路由器刷OpenWrt官方最新版本固件OpenWrt 23.05.2方法 其他型号的智能路由器OpenWrt固件刷入方法也基本上适用

最近路由器在开机时总出问题,于是就那他来开刀,直接刷一个OpenWrt官方最新版本的固件, 刷其他第三方的固件总是觉得不安全, 而且很多第三方固件都带了些小工具,始终会有安全隐患, 而且占用内存空间太多,本来这个东西就没有多少内存,于是就干脆刷一个官方的原始固件(才6.3M, 相…

使用numpy处理图片——滤镜

大纲 3维数组切分打平重组法深度切分法 3维数组堆叠 我们在用手机拍照片时&#xff0c;往往会对照片进行滤镜处理&#xff0c;从而让照片更加美观。本文我们将实现几种滤镜效果——去除所有像素中的某一种原色&#xff0c;形成只有红绿、红蓝和绿蓝原色的照片。 为了突出色彩丰…

怎么投稿各大媒体网站?

怎么投稿各大媒体网站&#xff1f;这是很多写作者及自媒体从业者经常面临的问题。在信息爆炸的时代&#xff0c;如何将自己的文章推送到广大读者面前&#xff0c;成为了一个不可避免的挑战。本文将为大家介绍一种简单有效的投稿方法——媒介库发稿平台发稿&#xff0c;帮助大家…

可重入锁和不可重入锁

概念 Reentrant Re entrant&#xff0c;Re是重复、又、再的意思&#xff0c;entrant是enter的名词或者形容词形式&#xff0c;翻译为进入者或者可进入的&#xff0c;所以Reentrant翻译为可重复进入的、可再次进入的&#xff0c;因此ReentrantLock翻译为重入锁或者再入锁。 可…

SpringCloud微服务 【实用篇】| RabbitMQ快速入门、SpringAMQP

目录 一&#xff1a;初始RabbitMQ 1. 同步和异步通讯 1.1 同步调用 1.2 异步调用 2. MQ常见框架 二&#xff1a;RabbitMQ快速入门 1. RabbitMQ概述和安装 2. 常见消息队列模型 3. 快速入门案例 三&#xff1a;SpringAMQP 1. Basic Queue 简单队列模型 2. Work Queu…

尝试OmniverseFarm的最基础操作

目标 尝试OmniverseFarm的最基础操作。本地机器作为Queue和Agent&#xff0c;同时在本地提交任务。 主要参考了官方文档&#xff1a; Farm Queue — Omniverse Farm latest documentation Farm Agent — Omniverse Farm latest documentation Farm Examples — Omniverse Far…

遥感单通道图像保存为彩色图像

系列文章目录 第一章PIL单通道图像处理 文章目录 系列文章目录前言一、代码实现二、问题记录在这里插入图片描述 总结 前言 将单通道图像以彩色图像的形式进行保存主要使用了PIL库 一、代码实现 palette_data [***]&#xff1a;可以进行自定义设置 代码如下&#xff1a; fr…