STL解析——list的使用

news2025/6/7 12:17:54

目录

1.简介

2.构造函数

3.迭代器

3.1封装

3.2迭代器分类

4.排序性能

4.1链式与数组

4.2缓存读取


1.简介

STL容器中提供的list容器也是一种顺序容器,底层实现方式是带头双向链表,这种实现方式能比单链表更高效的访问数据。

 下面围绕部分重要接口的使用展开讲解。

2.构造函数

list的构造函数提供了空初始化、元素个数初始化、迭代器区间初始化等

这里只需注意迭代器区间初始化除了使用list容器的迭代器区间,也可使用其他类迭代器区间。代码演示如下:

void list_test01()
{
	//空初始化
	list<int> lt1;
	for (auto e : lt1)
	{
		cout << e << ' ';
	}
	cout << endl << endl;

	//元素个数(size)初始化
	list<int> lt2(10, 1);
	for (auto e : lt2)
	{
		cout << e << ' ';
	}
	cout << endl << endl;

	//迭代器区间初始化
	list<int> lt3(lt2.begin(), lt2.end());
	for (auto e : lt3)
	{
		cout << e << ' ';
	}
	cout << endl;
	int arr[] = { 0,1,2,3,4 };
	list<int> lt4(arr, arr + 5);
	for (auto e : lt4)
	{
		cout << e << ' ';
	}
	cout << endl << endl;

}

打印结果如下: 

3.迭代器

3.1封装

之前我门在学习string和vector时,模拟实现的迭代器是一种指针,通过指针的加减和解引用能快速迭代容器内元素,但这仅是对string和vector底层仅是数组结构的迭代器实现方式。对于链表这种底层空间不连续的链式结构,通过指针是无法顺利迭代容器内元素的,但我们还是可以将迭代链表元素的方式封装成迭代器。

迭代器的功能是通过简单的加减和解引用方式来访问容器内元素,因此对于链表这种结构我们可以将迭代器创建为一种类,将访问链表的底层代码放入类中实现,再将迭代器类的运算符进行重载,进而封装成我们现在看到的迭代器。这种将底层复杂的方式抽象整合为一种统一的方式的思想,就体现了封装思想。

拿现实中例子举例,类似于移动支付未出现前的银行卡,各银行的底层识别方式不同,因此跨行操作及其不方便,但微信/支付宝的移动支付则是将这种底层识别封装为统一的支付款,减小了底层差异带来的影响。

拿list的迭代器区间初始化举例:

void list_test02()
{
	string s =  "abcdef";
	vector<int> v1 = { 1,1,1,1,1,1,1 };
	list<int> l1 = { 0,0,0,0,0, };

	list<char> lt1(s.begin(), s.end());
	list<char> lt2(v1.begin(), v1.end());
	list<char> lt3(l1.begin(), l1.end());
}

若没有封装迭代器,那么对于跨容器初始化我们需要对每种容器都进行实现方式,调用时及其不方便。但我们将各容器封装了迭代器,由此可进行统一的迭代器初始化。

3.2迭代器分类

在对之前文档进行查看时不难发现,不同函数的接口的迭代器名称不同:

像排序(sort)的随机迭代器

逆置(reverse)的双向迭代器

删除(remove)的单向迭代器

因此迭代器的分类大体如下:

(1)随机迭代器:随机迭代器的意思是能任意访问迭代器中任何位置,像vector和string底层为数组结构的迭代器就是随机迭代器。可以进行++,--,+,- 操作。

(2)双向迭代器:双向迭代器意思是可以向前或向后依次访问元素,但只能从一个数据访问到下一个或前一个数据,不能随意访问任意元素,像list这种双向链表就是双向迭代器。可以进行++和--。

(3)单向迭代器:只能向前依次访问数据,像数据结构中的单链表就是单向迭代器。只能进行++。

三种迭代器的关系类似功能继承,比如单向迭代器能用的地方双向迭代器也能用,而双向迭代器能用的地方,单向迭代器不一定能用。 

以sort进行举例:

void list_test03()
{
	vector<int> v1 = { 10,2,3,5,1,9 };
	list<int> lt1 = { 10,2,3,5,1,9 };

	sort(v1.begin(), v1.end());
	sort(lt1.begin(), lt1.end());
}

运行结果如下:

可以看到直接报错了。

4.排序性能

4.1链式与数组

list与vector都是顺序容器,list有自带的sort接口,vector排序主要使用函数库的sort函数,两个排序底层都是快排,按理来说两种容器的排序时间复杂度都是O(nlogn),但实际使用效率相同吗?根据下下面代码进行深入了解:

//排序效率
void list_test04()
{
	srand(time(0));
	const int N = 100000;

	list<int> lt1;
	vector<int> v;

	for (int i = 0; i < N; ++i)
	{
		auto e = rand() + i;
		lt1.push_back(e);
		v.push_back(e);
	}

	int begin1 = clock();
	// 排序
	sort(v.begin(), v.end());
	int end1 = clock();

	int begin2 = clock();
	lt1.sort();
	int end2 = clock();

	printf("vector sort:%d\n", end1 - begin1);
	printf("list sort:%d\n", end2 - begin2);
}

此代码最后会打印两种容器排序所需的实际时间(ms),运行(VS2022,X86,release环境)结果如下:

可以看到时间list的性能是比vector差很多的,那相同的时间复杂度为何差异如此之大呢?

4.2缓存读取

主要原因是和内存缓存有关,由于内存的读取性能较差,为了高效读取数据,在内存与cpu间设置了缓存器,缓存器的主要特点是内存小、读取速度快。对于数组这样的连续结构,会一次将多个字节数据储存在缓存器中,那么cpu对于vector数据的读取在缓存器中命中率更高,而list的数据不是连续内存存储,因此命中率会更低。由此导致了list与vector的时间效率不同。

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

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

相关文章

MQTTX连接阿里云的物联网配置

本文的目标是通过MQTTX的客户端&#xff0c;连接到阿里云的物联网的平台&#xff0c;发送温度信息&#xff0c;在阿里云的平台中显示出来。阿里云免费注册&#xff0c;免费有一个MQTT的服务器。有数量限制&#xff0c;但是对于测试来讲&#xff0c;已经足够。 1、注册阿里云的物…

20250606-C#知识:匿名函数、Lambda表达式与闭包

C#知识&#xff1a;匿名方法、Lambda表达式与闭包 闭包乍一听感觉很复杂&#xff0c;其实一点也不简单 1、匿名方法 没有方法名的方法一般用于委托和事件 Func<int, int, int> myAction delegate(int a, int b) { return a b; }; Console.WriteLine( myAction(1, 2)…

衡量嵌入向量的相似性的方法

衡量嵌入向量的相似性的方法 一、常见相似性计算方法对比 方法核心原理公式优点缺点适用场景余弦相似度计算向量夹角的余弦值,衡量方向相似性,与向量长度无关。$\text{cos}\theta = \frac{\mathbf{a} \cdot \mathbf{b}}{\mathbf{a}\mathbf{b}欧氏距离计算向量空间中的直线距离…

API是什么意思?如何实现开放API?

目录 一、API 是什么 &#xff08;一&#xff09;API 的定义 &#xff08;二&#xff09;API 的作用 二、API 的类型 &#xff08;一&#xff09;Web API 1. RESTful API 2. SOAP API &#xff08;二&#xff09;操作系统 API &#xff08;三&#xff09;数据库 API …

Python训练第四十六天

DAY 46 通道注意力(SE注意力) 知识点回顾&#xff1a; 不同CNN层的特征图&#xff1a;不同通道的特征图什么是注意力&#xff1a;注意力家族&#xff0c;类似于动物园&#xff0c;都是不同的模块&#xff0c;好不好试了才知道。通道注意力&#xff1a;模型的定义和插入的位置通…

第2天:认识LSTM

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 目标 具体实现 &#xff08;一&#xff09;环境 语言环境&#xff1a;Python 3.10 编 译 器: PyCharm 框 架: pytorch &#xff08;二&#xff09;具体步骤…

自动化提示生成框架(AutoPrompt)

自动化提示生成框架(AutoPrompt) 一、核心创新点 自动化提示生成框架(AutoPrompt) 创新本质:提出基于梯度引导搜索的自动化提示生成方法,替代人工设计模板的传统模式。技术路径: 将提示视为可训练的离散token序列,通过优化提示向量(prompt embedding)搜索语义空间。利…

中国首套1公里高分辨率大气湿度指数数据集(2003~2020)

时间分辨率&#xff1a;月空间分辨率&#xff1a;100m - 1km共享方式&#xff1a;开放获取数据大小&#xff1a;34.79 GB数据时间范围&#xff1a;2003-01-01 — 2020-12-31元数据更新时间&#xff1a;2023-07-26 数据集摘要 中国首套1公里高分辨率大气湿度指数数据集&#xf…

计算机视觉顶刊《International Journal of Computer Vision》2025年5月前沿热点可视化分析

追踪计算机视觉领域的前沿热点是把握技术发展方向、推动创新落地的关键&#xff0c;分析这些热点&#xff0c;不仅能洞察技术趋势&#xff0c;更能为科研选题和工程实践提供重要参考。本文对计算机视觉顶刊《International Journal of Computer Vision》2025年5月前沿热点进行了…

python学习打卡day45

DAY 45 Tensorboard使用介绍 知识点回顾&#xff1a; tensorboard的发展历史和原理tensorboard的常见操作tensorboard在cifar上的实战&#xff1a;MLP和CNN模型 效果展示如下&#xff0c;很适合拿去组会汇报撑页数&#xff1a; 作业&#xff1a;对resnet18在cifar10上采用微调策…

Verilog编程技巧01——如何编写三段式状态机

前言 Verilog编程技巧系列文章将聚焦于介绍Verilog的各种编程范式或者说技巧&#xff0c;编程技巧和编程规范有部分重合&#xff0c;但并非完全一样。规范更注重编码的格式&#xff0c;像变量命名、缩进、注释风格等&#xff0c;而编程技巧则更偏重更直观易读、更便于维护、综合…

智启未来:当知识库遇见莫奈的调色盘——API工作流重构企业服务美学

目录 引言 一、初识蓝耘元生代MaaS平台 1.1 平台架构 1.2 平台的优势 1.3 应用场景 二、手把手教你如何在蓝耘进行注册 &#xff08;1&#xff09;输入手机号&#xff0c;将验证码正确填入即可快速完成注册 &#xff08;2&#xff09;进入下面的页面表示已经成功注册&…

如何在 Windows 11 中永久更改默认浏览器:阻止 Edge 占据主导地位

在 Windows 11 中更改默认浏览器对于新手或技术不太熟练的用户来说可能会令人沮丧。 为什么要在 Windows 11 中更改默认浏览器? 这是一个重要的问题:你为什么要从 Microsoft Edge 切换过来? 生态系统集成:如果你已经在广泛使用 Google 服务,Chrome 可以提供无缝集成。同…

量子比特实现方式

经典计算机是通过电子电路运转起来的。使用硅制半导体制成的名为晶体管的小元件发挥了开关的作用&#xff0c;将其与金属布线组合起来即可实现逻辑门&#xff0c;再将逻辑门集成起来就能制造出经典计算机。量子计算机的制造过程则要复杂许多&#xff0c;因为量子计算机既需要量…

智慧水务发展迅猛:从物联网架构到AIoT系统的跨越式升级

AI大模型引领智慧水务迈入新纪元 2025年5月25日&#xff0c;水利部自主研发的“水利标准AI大模型”正式发布&#xff0c;它标志着水务行业智能化进程的重大突破。该模型集成1800余项水利标准、500余项法规及海量科研数据&#xff0c;支持立项、编制、审查等全流程智能管理&…

Java高级 | 【实验五】Spring boot+mybatis操作数据库

隶书文章&#xff1a;Java高级 | &#xff08;二十二&#xff09;Java常用类库-CSDN博客 系列文章&#xff1a;Java高级 | 【实验一】Springboot安装及测试 |最新-CSDN博客 Java高级 | 【实验二】Springboot 控制器类相关注解知识-CSDN博客 Java高级 | 【实验三】Springboot 静…

在MATLAB中使用自定义的ROS2消息

简明结论&#xff1a; 无论ROS2节点和MATLAB运行在哪&#xff0c;MATLAB本机都必须拥有自定义消息源码并本地用ros2genmsg生成&#xff0c;才能在Simulink里订阅这些消息。只要你想让MATLAB或Simulink能识别自定义消息&#xff0c;必须把消息包源码(.msg等)拷到本机指定目录&a…

【MATLAB去噪算法】基于ICEEMDAN联合小波阈值去噪算法

ICEEMDAN联合小波阈值去噪算法相关文献 &#xff08;注&#xff1a;目前相关论文较少&#xff0c;应用该套代码可发直接一些水刊&#xff09; 一、CEEMDAN的局限性 模式残留噪声问题&#xff1a;原始CEEMDAN在计算每个IMF时直接对噪声扰动的信号进行模态分解并平均。 后果&a…

XXTEA,XTEA与TEA

TEA、XTEA和XXTEA都是分组加密算法&#xff0c;它们在设计、安全性、性能等方面存在显著区别。以下是它们的主要区别&#xff1a; 密钥长度 TEA&#xff1a;使用128位密钥。 XTEA&#xff1a;通常使用128位或256位密钥。 XXTEA&#xff1a;密钥长度更灵活&#xff0c;可以使用任…

机器人玩转之---嵌入式开发板基础知识到实战选型指南(包含ORIN、RDK X5、Raspberry pi、RK系列等)

1. 基础知识讲解 1.1 什么是嵌入式开发板&#xff1f; 嵌入式开发板是一种专门设计用于嵌入式系统开发的硬件平台&#xff0c;它集成了微处理器、内存、存储、输入输出接口等核心组件于单块印刷电路板上。与传统的PC不同&#xff0c;嵌入式开发板具有体积小、功耗低、成本适中…