list容器 黑马程序员c++

本文详细介绍了C++ STL中的list容器,包括其基本概念、构造函数、赋值与交换、大小操作、插入与删除、数据存取、反转与排序。list是一个双向循环链表,其优点在于方便插入和删除,但遍历速度较慢。在list中,插入和删除不会导致迭代器失效,与vector不同。此外,list提供了内置的排序功能,但自定义数据类型的排序需指定比较规则。
摘要由CSDN通过智能技术生成

1.1 基本概念

功能:将数据进行链式存储

链表是一种物理存储单元上非连续的存储结构,数据元素的逻辑顺序是通过链表中的指针链接实现的

链表的组成:链表由一系列结点组成

结点的组成:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域

STL中的链表是一个双向循环链表

链表的优点:可以对任意位置进行快速插入或删除元素

缺点:容器遍历速度,没有数组快;占用的空间比数组要大

由于链表的存储方式并不是连续的内存空间,因此链表list中的迭代器只支持前移和后移,属于双向迭代器 也就是说,不能由迭代器+数字的情况出现!只能一个一个来

list采用动态存储分配,不会造成内存浪费和溢出

list有一个重要的性质,插入操作和删除操作都不会造成原有list迭代器的失效,这在vector中式不成立的

(因为vector容器的插入,会另外选择一块更大的内存空间,并把整体“搬”过去,而之前的迭代器还指向的是之前的那一块内存,因此也就失效了)

总结:STL中list和vector是两个最常被使用的容器,各有优缺点

1.2 list构造函数

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值