C++学习18:容器深度探索之list源码剖析、迭代器的移动和取值

对于容器部分的初步理解请见C++学习17:容器初步理解
本次主要进行list的部分重要源码的剖析。

1 list部分源代码

在这里插入图片描述
list是双向链表,类中只有一个数据是node,是一个指向list_node(节点)的指针。(代码框中第二个,图中的红色指针)
在这里插入图片描述
list_node类型存有三个变量,一个是指向前驱节点的指针pred,一个是指向后继节点的指针next,最后一个是值data。前两个指针是void*类型,即point to void(图中是三层的矩形叠加的东西)
在这里插入图片描述

2 迭代器的4个操作符重载

从下面源码得知,迭代器的操作一般有很多typedef(其中做注释的5个是迭代器的traits,在下一节中会讲到)也一定有4个操作符重载。在这里插入图片描述

2.1 迭代器的移动

关于迭代器指向后一位,要进行操作符重载operator++()operator++(int),operator++()表示前++,operator++(int)表示后++。
list中还有一个迭代器__list_iterator。iterator是个聪明的指针,指向下一个节点的方式是指向它的next。在list中,可以看出这个++动作就是(*node).next 赋值node中,就相当于node这个泡泡走向了下一个位置。具体代码如下所示:
在这里插入图片描述
上图中,圈1中要先进行等号的拷贝构造,故*this是拷贝构造函数的参数,而非进行星号的运算符重载。

2.2 迭代器的取值

需要重载 operator*operator-> 。操作如下:
在这里插入图片描述

3 list的改进

3.1 迭代器

1、void*被改为指向自己的类型,更为精确。
2、模板参数由3个变为1个,更易懂。

3.2 新版本list与forward_list

相对而言复杂了很多,比起之前的版本多了4bit。
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值