C++的list数据结构

 时间:2024-11-08 17:03:36

双向循环链表list

list是双向循环链表,每一个元素都知道前面一个元素和后面一个元素。在STL中,list和vector一样,是两个常被使用的容器。和vector不一样的是,list不支持对元素的任意存取。list中提供的成员函数与vector类似,不过list提供对表首元素的操作push_front、pop_front,这是vector不具备的。和vector另一点不同的是,list的迭代器不会存在失效的情况,他不像vector会保留备份空间,在超过容量额度时重新全部分配内存,导致迭代器失效;list没有备份空间的概念,出入一个元素就申请一个元素的空间,所以它的迭代器不会失效。

C++的list数据结构list初始化时,申请的空间大小为6,存放下了data中的6个元素,当向lidata插入第7个元素“6”时,list申请新的节点单元,插入到list链表中,数据存放结构如图1所示:

C++的list数据结构list每次增加一个元素,不存在重新申请内存的情况,它的成本是恒定的。而vector每当增加关键元素的时候,都需要重新申请新的更大的内存空间,会调用元素的自身的复制构造函数,存在构造成本。在销毁旧内存的时候,会调用析构函数,存在析构成本。所以在存储复杂类型和大量元素的情况下,list比vector更有优势!

  • 在pycharm中配置Anaconda的python工具包
  • java中如何定义一个字符串
  • intellij idea如何设置程序运行环境为jre8
  • IDEA创建Java Web项目
  • 如何用C语言产生随机数并写入文件中
  • 热门搜索
    魏巍简介 怎么上传视频到网上 万家乐壁挂炉怎么样 法门寺简介 初中古诗大全 陶行知简介 猪兼强驾校怎么样 农具大全 银杏怎么吃 2岁宝宝食谱大全及做法