news 2026/1/20 16:19:58

cpp中list的解析和底层代码的简单实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
cpp中list的解析和底层代码的简单实现

1.list的使用方法(list 本质上是一个双链表 )

list的迭代器类型是双向迭代器(支持++,--)

1)构造函数()

默认构造函数

default (1)
explicit list (const allocator_type& alloc = allocator_type());

这个构造就是构造出哨兵位(头节点) allocator_type() 这个是对于不同类型的0值,对于char就是‘0’

range (3)
template <class InputIterator> list (InputIterator first, InputIterator last, const allocator_type& alloc = allocator_type());
copy (4)
list (const list& x);

range 构造函数的InputIterator是 C++ 标准中的输入迭代器(及兼容它的更高阶迭代器:前向、双向、随机访问迭代器),并非任意迭代器,输出迭代器不支持该构造

2)list的push

有push_back和push_front 这两个 对于双量表而言,时间复杂度都是O(1) 。

还有一种emplace_back 在某种情况下是比push_back 而言是高效一点的。这种特殊情况就是对要插入的元素没有操作时他就可以减少拷贝直接构造

3)迭代器访问

begin() end()

这里begin() 返回的是头节点的后面一个iterator(即第一个有效元素) end() 返回的是头节点iteraotr(最后一位有效元素的下一位)

4)任意位置的增加和删除 insert erase

iteraotr insert(iterator pos,T& val)

返回值仍是指向着新的元素,

iterator erase(iterator pos)

iterator erase(iterator first,iterator last)

这里的返回值是指向着擦除元素最后一位的下一位,对于第一个pos就是指向pos的下一位,这些和vector都是差不多的,同样需要防止迭代器失效!!!

这里的插入时前闭后开

5)splice

这个可以理解成 CTRL + C ,delete,到指向的位置CTRL+V,意思是将一段list拼接到另一个list的 pos 后面但是第一个list会被销毁。

来具体解析一下第三个,iterator position 代表的是我要插入到 list1 的哪个位置,list&x代表的是我要把哪个list插入,iterator first,iterator last 指的是插入区间,同样是前闭后开;

6)merge 中文译为整合

他这个是针对于有序list之间的整合,比如有两个递增的list我想构造出一个递增的新list

来细讲一下2 这个就是list的引用,comp是排序规则,必须和list的排序规则相同!!!

7)sort

重点:标准库中有一个 sort ,list 中有一个sort,那为什么要设计这么多个sort,不能统一吗

可以明确的看出标准库的sort是只是用随机迭代器的,而list在开篇就讲过了这是双向迭代器,所以list要单独设计,问题就出现在这里,按照道理来说标准库应该是没有这个专门的为双向设计的迭代器效率高的,大数据量下,标准库的std::sort(用于vector等支持随机访问迭代器的容器)效率是std::list::sort的两倍以上(明确两个sort的区别,避免笔误混淆)。

所以我们要排序可以直接用构造函数,用list构造出一个vector,在进行排序,效率都比直接用list的库sort效率高很多!!!可以进行测试时间(用release模式,毕竟最后看的是这个模式的效率如何)。

2.底层代码

底层代码值得一聊的就是对iterator的封装,我们用一个类对list_node* 进行封装,这个行为使得我们可以进行运算符重载,从而实现 * ++ != == 这样的东西,也可使先const_iterator 和iterator,毫无疑问这个是list_node* 直接无法实现的东西,这个完美体现了封装的魅力。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/20 14:00:20

django-flask基于python篮球比赛CBA联赛管理系统pycharm -Vue

目录系统概述技术架构核心功能部署与扩展关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统概述 基于Python的CBA联赛管理系统整合Django与Flask框架&#xff0c;后端采用Django处…

作者头像 李华
网站建设 2026/1/20 11:57:06

想玩 CTF?先搞懂这三点:是什么、有何用、怎么入门

什么是网络安全CTF?有何意义&#xff1f;该如何入门&#xff1f; 什么是网络安全CTF?有何意义 &#xff1f;该如何入门 &#xff1f; 什么是网络安全CTF? CTF在网络安全领域中指的是网络安全技术人员之间进行技术竞技的一种比赛形式。它起源于1996年DEFCON全球黑客大会&a…

作者头像 李华
网站建设 2026/1/19 5:45:40

服务器防护必修课:Linux 系统如何有效抵御 DDoS 攻击

Linux服务器防护篇&#xff1a;击退DDoS攻击 一、什么是 DDoS 攻击 简单来说&#xff0c;DDoS 攻击&#xff0c;即分布式拒绝服务攻击&#xff08;Distributed Denial of Service&#xff09; &#xff0c;是一种通过利用大量傀儡机&#xff08;也被称为 “肉鸡”&#xff09;…

作者头像 李华
网站建设 2026/1/19 9:35:13

单北斗GNSS技术在变形监测中的应用及其位移监测优势解析

本文主要围绕单北斗GNSS技术在变形监测中的应用进行探讨。单北斗GNSS技术以其高精度和实时性&#xff0c;使得在地质灾害监测和基础设施安全评估中发挥着重要作用。通过使用单北斗变形监测一体机&#xff0c;可以有效获取位移信息&#xff0c;从而为工程师提供及时的数据支持。…

作者头像 李华
网站建设 2026/1/18 16:22:54

三相电压型PWM整流器仿真分析与研究:关键技术及应用探索

三相电压型PWM整流器仿真资料三相电压型PWM整流器这玩意儿搞电力电子的应该都熟&#xff0c;今天咱们用Simulink搭个仿真模型实战下。直接从主电路开整——六个IGBT管子摆成桥臂&#xff0c;中间接个LC滤波器&#xff0c;电网侧串点电感模拟线路阻抗。别小看这个LC参数&#xf…

作者头像 李华