CPPlist初识

一.splice

std::list::splice

  • C++98
  • C++11

| entire list (1) | void splice (iterator position, list& x); |
| single element (2) | void splice (iterator position, list& x, iterator i); |

element range (3) void splice (iterator position, list& x, iterator first, iterator last);

作用:将链表转移,单个转移,部分转移到pos之前,并剪切链表的结点新增到调用的链表。

//这有效地将这些元素插入到容器中,并将它们从 x 中删除,从而更改了两个容器的大小。该操作不涉及任何元素的建造或破坏。无论 x 是左值还是右值,或者value_type是否支持移动构造,它们都会被转移。

规范:都要传迭代器,再list,定位用迭代器。

注意:自己转移:可以,把一个元素拿到另一个地方,可以结合std::find找某元素的迭代器。

二.杂项

模板实例化:只有在模板传入生成类/函数后才会详细检查语法错误

按需实例化:调用成员函数才会实例化那个成员函数

三.实现

list本质是带头双向链表

ListNode这样成员全部公有的一般用struct(不用写析构,由list同一调度)

迭代器封装Node*和++等操作(节点指针不符合迭代器++等行为)也是模板(各种Node*)

//全缺省必要传匿名对象

(1)遍历实现:

迭代器:vector迭代器可以用T*直接+到下一个位置,前提是空间连续

所以list迭代器要定义一个类重载部分运算符++,--,以找下一个位置

要重载的如:解引用,++,!=

可以用节点的指针构造

为了符合外部调用方式要typedef迭代器类型为iterator

不用析构资源,节点属于链表,(不是有成员是动态开辟的就要释放)

拷贝构造不用写(node*一样,指向同一节点)--->(一般一个类不写析构就不用自己写拷贝构造,默认的就够用)

重点:1.重载迭代器->

目的:取代迭代器的解引用再找成员

其实是两个箭头

cpp 复制代码
T* operator->()
{
return &_node->_data;//iterator里的Node*再找T*(迭代器的节点的数据的地址)
}

it->col;//其实是it->->col,简化语法
//it.operator->()->data

2.临时对象的常性

可以调用非静态的成员函数(包括非const),但不能给普通引用(编译器特殊处理)

3.const迭代器

普通迭代器前加const修饰的是迭代器本身,而不是指向的节点内部数据不能修改,const_iterator类似const P*,P能改,*P不能修改。

实现:让operator*,->访问的返回const类型

(不能让T变成const T,不然节点内部本身就变成了const,与list本身不同,迭代器传给list不能初始化等)

简化:const_iterator和iterator在外要手写两个类,可以让模板传const T和const T&,给const_iterator里*,->的返回值

4.insert和迭代器不会失效

因为list本身是个环,怎么扩容(增加单个节点不影响其他),迭代器不会指向无效位置

erase会失效,因为其指向节点的空间已经被释放

相关推荐
fy zs7 分钟前
网络编程套接字
linux·服务器·网络·c++
yuanmenghao7 分钟前
CAN系列 — (8) 为什么 Radar Object List 不适合“直接走 CAN 信号”
网络·数据结构·单片机·嵌入式硬件·自动驾驶·信息与通信
fpcc9 分钟前
模板编程—模板和元编程中的错误输出
c++·模板编程
xie_pin_an10 分钟前
C++ 类和对象全解析:从基础语法到高级特性
java·jvm·c++
小温冲冲15 分钟前
C++与QML信号绑定完全指南:实现跨语言无缝通信
c++
GIS 数据栈20 分钟前
【Seggis遥感系统升级】用C++高性能服务Drogon重构软件服务架构|QPS提升300%,性能再升级!
java·开发语言·c++·重构·架构
一条大祥脚21 分钟前
26.1.3 快速幂+容斥 树上dp+快速幂 带前缀和的快速幂 正序转倒序 子序列自动机 线段树维护滑窗
数据结构·算法
2301_7806698624 分钟前
List(特有方法、遍历方式、ArrayList底层原理、LinkedList底层原理,二者区别)
java·数据结构·后端·list
王老师青少年编程33 分钟前
信奥赛C++提高组csp-s之二分图
数据结构·c++·二分图·csp·信奥赛·csp-s·提高组
柏木乃一35 分钟前
进程(11)进程替换函数详解
linux·服务器·c++·操作系统·exec