C++-list容器常用接口的模拟实现

 list在stl中的定义:

list容器底层实现的数据结构:

一.list对象的实例化

1.链表结点结构的定义

2.list类模板的定义,并且实现简单的尾插功能

        

二.使用迭代器遍历链表中的元素

1.迭代器类型的定义

 这里定义迭代器的类型是为了通过对内的封装,而实现对外处理数据提供统一的方法。

2.begin() 和 end()

3.

 三.insert和erase

        1.insert

                在当前迭代器位置之前插入一个新的结点。

                这里返回新的迭代器是为了这样的情况:

        2.erase

                删除给定的迭代器的结点

                这里很明显会发生迭代器失效的问题,因为原结点已经被删除了,但是外部迭代器中还记录这原结点的地址,所以通过返回值解决。

                这里还需要注意一个问题:

        我们在通过迭代器遍历链表元素之前,头删一下,就会发生迭代器失效的问题,

四.clear和size

五.拷贝构造和赋值重载

这里还有一个写法,虽然在C++引入模板的概念之后类名就不代表类型了,但是:

这样写也是OK的。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值