[C++] 模拟实现list(一)

标题:[C++] 模拟实现list

@水墨不写bug



目录

一、list简介

二、铺垫

 I,分离编译模式的选择

II,数据结构分析

(1)命名空间

 (2)类的设计分析


正文开始:

一、list简介

        C++ STL(Standard Template Library,标准模板库)中的list容器是一个双向链表,它支持常数时间的元素插入和删除操作,而不需要重新分配整个容器或移动容器中的元素(除了插入或删除点附近的元素可能会移动)。

list容器的主要特点包括:

  1. 双向链表list内部实现为一个双向链表,每个元素都包含数据和指向列表中前后元素的指针。这允许快速向前和向后遍历链表。

  2. 动态大小list的大小可以根据需要动态增长或缩小,这是通过插入或删除元素来实现的。

  3. 随机访问不支持:与vectordeque等容器不同,list不支持随机访问,即不能使用下标来直接访问元素。要访问元素,必须使用迭代器或者成员函数如front()back()begin()end()等。

  4. 高效的插入和删除:在list的任何位置插入或删除元素都是高效的,因为只需要调整相关元素的指针即可,不需要移动或复制其他元素。

  5. 迭代器list提供双向迭代器,允许向前和向后遍历列表。然而,这些迭代器不是随机访问迭代器,因此不支持+-或数组下标操作符 [] 。

  6. 成员函数list提供了丰富的成员函数来管理容器中的元素,包括push_front()push_back()pop_front()pop_back()insert()erase()clear()size()empty()等。

  7. 内存分配list中的每个元素都是动态分配的,list会有比连续存储(如vector)更高的内存使用率。

二、铺垫

 I,分离编译模式的选择

         本文我们要实现的是与STL功能基本一致的list,通过实现一个list类模板从而可以指定存入数据的类型,由此实现的list具有更高的实用性和灵活性。

        但是在前面的文章《C++:模板进阶》中我们知道:在编译时期,模板不会实例化出对象,那么在链接时,编译器在寻找对象的地址时找不到,所以报错。解决方法就是需要将生命和定义放在一个 .h 文件中。        于是,我们实现的list也是将类模板直接放在一个.h文件中。

II,数据结构分析

(1)命名空间

        我们在实现list的时候,由于我么起的名字和STL中的名字完全相同,所以为了保险起见,我们需要将我们实现的项目放在自己的命名空间中,防止命名冲突。(命名空间的名称可以自己决定,但是不要和STL冲突)

namespace ddsm{

//.......
};

 (2)类的设计分析

        我们想要实现一个链表结构,首先需要是实现一个链表的节点类,于是,我们可以将链表的节点类实现如下:

template<typename T>
struct ListNode
{
	ListNode<T>* _prev;
	ListNode<T>* _next;
	T _data;

	ListNode(const T& val = T())
		:_prev(nullptr)
		,_next(nullptr)
		,_data(val)
	{}
};

         对于链表的一个节点,并没有需要特殊实现的功能。

        唯一需要注意的是,我们实现的是一个模板类,在构造函数中,缺省参数我们给了一个匿名对象,这是一个明智的选择:

        如果T是内置类型,假如是int,则对于如下代码:

int a = int();

        a会被初始化为0;

        如果T是自定义类型,则会在匿名对象实例化时,调用这个自定义类型的构造函数,也会得到初始化。

        然而仅仅有了list的一个节点是不够的,这只是第一步,接下来我们需要将链表的一个一个耳朵节点链接起来,这就需要另一个类来维护整个链表。 

         我们把将要实现的维护一整个链表的类命名为list(此命名在命名空间ddsm中不必担心命名冲突问题),一般我们通过首节点的指针来维护这一整个链表,于是list类框架如下:

template<class T>
class list
{
	typedef ListNode<T> Node;

private:
	Node* _pHead;
};

        但是我们发现:

        STL的list的迭代器是可以进行自增,自减操作并实现链表迭代器的移动的,如果我们就只按照上面的方式来实现链表,就会发现我们的迭代器(ListNode<T>* 指针)是没有办法进行自增自减来达到迭代器移动的目的的。为了尽可能贴近STL的实现方法,同时更底层的了解STL内部的实现方式,我们可以这样选择:

        对迭代器进行封装,把迭代器类型(ListNode<T>* 指针)封装为包含(ListNode<T>* 指针)的类,一样一来,一旦有了类,我们就可以对其对象操作符进行重载,这样我们就可以在重载函数内实现自己想要的操作!


        总结来说:原来的Node*不符合我想要的行为,我们可以通过对Node*封装为ListIterator,在ListIterator内重载操作符来控制Node*的行为。

        于是,第三个类就是对指针的封装,将(ListNode<T>* 指针)封装为包含(ListNode<T>* 指针)的类,目的是对(ListNode<T>* 指针)的操作符进行重载,这里我们把类名定为ListIterator,防止与其他容器的迭代器类型混淆。

template<typename T>
struct ListIterator
{
    typedef ListNode<T> Node;

	 Node* _node;
};

未经作者同意禁止转载 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

成功登上主要中心化交易所 (CEX) 的终极指南:从准备到上市的全面策略

对于区块链项目的创始人而言&#xff0c;成功的代币发行是项目发展的关键一步。尤其是在主要中心化交易所 (CEX) 上上市代币&#xff0c;可以极大地提高项目的曝光度和流动性。然而&#xff0c;CEX 上市过程复杂且充满挑战&#xff0c;需要创始人提前做好充分准备。本文将详细介…

Postman使用教程【项目实战】

目录 引言软件下载及安装项目开发流程1. 创建项目2. 创建集合(理解为&#xff1a;功能模块)3. 设置环境变量&#xff0c;4. 创建请求5. 测试脚本6. 响应分析7. 共享与协作 结语 引言 Postman 是一款功能强大的 API 开发工具&#xff0c;它可以帮助开发者测试、开发和调试 API。…

【绿色版】Mysql下载、安装、配置与使用(保姆级教程)

大家都知道&#xff0c;Mysql安装版的卸载过程非常繁琐&#xff0c;而且卸载不干净会出现许多问题&#xff0c;很容易让大家陷入重装系统的窘境。基于此&#xff0c;博主今天给大家分享绿色版Mysql的安装、配置与使用。 目录 一、Mysql安装、配置与使用 1、下载解压 2、创建…

Day06-角色管理-员工管理

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.编辑角色-进入行内编辑2.角色管理-行内编辑-数据缓存3.角色管理-编辑角色-确定取消4.角色管理-删除角色员工管理-页面结构6.员工管理-左侧树7.员工管理-选中首个节…

ubuntu虚拟机安装samba server实现windows访问虚拟机文件

1. ubuntu下安装samba 1.1 安装samba sudo apt install net-tools # 不能使用ifconfig需要先安装net-tools sudo apt-get install samba1.2 配置samba用户 sudo smbpasswd -a guomq # 新增用户guomq&#xff0c;新增的时候需要设置密码&#xff0c;我们根据提示设置即可修改…

Jmeter+Ant+Git+Jenkins持续集成介绍

一 简介 1.什么是ant? ant是构建工具 2.什么是构建 概念到处可查到&#xff0c;形象来说&#xff0c;你要把代码从某个地方拿来&#xff0c;编译&#xff0c;再拷贝到某个地方去等等操作&#xff0c;当然不仅于此&#xff0c;但是主要用来干这个 3.ant的好处 跨平台 -…

程序员学长 | PyCaret,一个超强的 python 库

本文来源公众号“程序员学长”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;PyCaret&#xff0c;一个超强的 python 库 今天给大家分享一个超强的 python 库&#xff0c;PyCaret。 https://github.com/pycaret/pycaret 简介 …

一文看尽:各大数据公司和 AI 结合进展

一、前言 前面给大家梳理了一下大数据领域领先厂商 snowflake 和 databricks 的最新进展&#xff0c;还挺受欢迎&#xff0c;都是大几千的阅读量。没有看过的可以翻看下面的链接&#xff1a; 大模型时代最懂数据的公司 databricks snowflake 不再是个数据仓库公司了 应该说…

高效应对网络攻击,威胁检测响应(XDR)平台如何提升企业应急响应能力

在数字化时代&#xff0c;企业面临的网络攻击威胁持续增加&#xff0c;如恶意软件、勒索软件、钓鱼攻击、DDoS攻击等。这些威胁不仅危及企业数据安全、系统稳定&#xff0c;还损害了品牌形象和市场信任。随着云计算、大数据、物联网的广泛应用&#xff0c;企业网络攻击面扩大&a…

【2024_CUMCM】TOPSIS法(优劣解距离法)

目录 引入 层次分析法的局限性 简介 例子 想法1 想法2 运用实际分数进行处理 想法3 问题 扩展问题&#xff1a;增加指标个数 极大型指标与极小型指标 统一指标类型-指标正向化 标准化处理 计算公式 计算得分 对原公式进行变化 升级到m个指标和n个对象 代码 …

Python酷库之旅-第三方库Pandas(014)

目录 一、用法精讲 34、pandas.DataFrame.to_parquet函数 34-1、语法 34-2、参数 34-3、功能 34-4、返回值 34-5、说明 34-6、用法 34-6-1、数据准备 34-6-2、代码示例 34-6-3、结果输出 35、pandas.read_sql_table函数 35-1、语法 35-2、参数 35-3、功能 35-4…

防御笔记第四天(持续更新)

1.状态检测技术 检测数据包是否符合协议的逻辑顺序&#xff1b;检查是否是逻辑上的首包&#xff0c;只有首包才会创建会话表。 状态检测机制可以选择关闭或则开启 [USG6000V1]firewall session link-state tcp ? check Indicate link state check [USG6000V1]firewall ses…

Rejetto HFS 服务器存在严重漏洞受到攻击

AhnLab 报告称 &#xff0c;黑客正在针对旧版本的 Rejetto HTTP 文件服务器 (HFS) 注入恶意软件和加密货币挖矿程序。 然而&#xff0c;由于存在错误&#xff0c; Rejetto 警告用户不要使用 2.3 至 2.4 版本。 2.3m 版本在个人、小型团队、教育机构和测试网络文件共享的开发…

MySQL高级----详细介绍MySQL中的锁

概述 锁是计算机协调多个进程或线程并发访问某一资源的机制&#xff0c;为了解决数据访问的一致性和有效性问题。在数据库中&#xff0c;除传统的计算资源(CPU、RAN、I/O&#xff09;的争用以外&#xff0c;数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、…

将Hyper-V虚拟机与主机共享网络

Hyper-V 网络设置 目标 将Hyper-V虚拟机网络配置为与主机使用同一网络&#xff0c;并确保主机网络连接不受影响。 前提条件 主机上已安装Hyper-V已创建Hyper-V虚拟机 步骤 1. 配置主机网络共享 打开 控制面板 -> 网络和 Internet -> 网络连接。右键点击 WIAN,选择…

顶刊中的“水”刊!录取率>90%,十投九中,含金量高,近期1个月就录用!

本周投稿推荐 SCI • 能源科学类&#xff0c;1.5-2.0&#xff08;25天来稿即录&#xff09; • CCF推荐&#xff0c;4.5-5.0&#xff08;2天见刊&#xff09; • 生物医学制药类&#xff08;2天逢投必中&#xff09; EI • 各领域沾边均可&#xff08;2天录用&#xff09…

游戏AI的创造思路-技术基础-情感计算(1)

游戏中的AI也是可以和你打情感牌的哦&#xff0c;不要以为NPC是没有感情的&#xff0c;不过&#xff0c;不要和NPC打过多的情感牌&#xff0c;你会深陷其中无法自拔的~~~~~~ 目录 1. 情感计算算法定义 2. 发展历史 3. 公式和函数 3.1. 特征提取阶段 TF-IDF&#xff08;词频…

vue 自定义(hook)--(模块化)

文章目录 定义示例代码 定义 什么是hook&#xff1f;—— 本质是一个函数&#xff0c;把setup函数中使用的Composition API进行了封装&#xff0c;类似于vue2.x中的mixin。 自定义hook的优势&#xff1a;复用代码, 让setup中的逻辑更清楚易懂。 示例代码 useSum.ts中内容如下…

Linux基础指令解析+项目部署环境

文章目录 前言基础指令部署项目环境总结 前言 Linux的魅力在于其强大的可定制性和灵活性&#xff0c;这使得它成为了众多开发者和运维人员的首选工具。然而&#xff0c;Linux的指令系统庞大而复杂&#xff0c;初学者往往容易迷失其中。因此&#xff0c;本文将带领大家走进Linu…

第三期书生大模型实战营 第1关 Linux 基础知识

第三期书生大模型实战营 第1关 Linux 基础知识 第三期书生大模型实战营 第1关 Linux 基础知识InternStudio开发机创建SSH密钥配置通过本地客户端连接远程服务器通过本地VSCode连接远程服务器运行一个Python程序总结 第三期书生大模型实战营 第1关 Linux 基础知识 Hello大家好&a…