c++ vs2019 cpp20 规范,set源码分析

(1)set模板和map模板都是继承于一个父类

所以没有再详细注释。维持红黑树主要的功能都在父类_Tree里了,比如节点的添加,删除,查找。父类红黑树的操作,并不依赖于特定的数据类型。做到了父类模板的通用性。那它是怎么做到的呢?以下介绍一下map与set的异同与操作上的兼容。

(2)set中节点的数据结构

这是map的数据结构。我也没有再重新绘制。因为跟set数据结构的唯一区别就是第四项不再存储pair<const _Kty, _Ty>,而是只存储 _Kty 。为什么呢?以下给出以下泛型推导。参考下图:

set接受模板参数后,把参数传递给父类 _Tree,父类 又把模板实参传递给_Tset_traits,这是1。

在箭头2中,_Tset_traits 据此定义了value_type 类型:using value_type = _Kty;。

箭头3 , _Tree 引用了_Traits::value_type类型,并据此创建了set的节点类型_Node。

如此,在箭头4创建节点时,包含的就仅有 _Kty 值了。如此,捋出来了set的节点的数据结构。

(3)在红黑树中怎么查找节点

map和set中都是直接引用的父类中的查找函数find(图中红框所示)。图中黄色箭头展示了,查找过程中的函数调用关系。父类_Tree 中是如何对两种树都可以查找呢?是差异性的调用了两个不同模板中的同名函数_Kfn(),所以仍然可以获得树节点中的键值。

无论树节点的插入和删除,都涉及对节点位置的查找。而后节点的插入与删除,是节点级别,与树节点中存储的数据类型就没有关系了。

至此红黑树的主要内容就结束了。很多操作,无非就是节点的插入和删除,包括树合并。

更详细注释,参见map源码分析。那个是第一遍做的。谢谢,感恩一切。

相关推荐
keep intensify3 分钟前
Redis基础指令全解析:从入门到精通
linux·数据库·c++·redis
梵得儿SHI9 分钟前
Java 反射机制深度解析:从运行时 “解剖” 类的底层逻辑
java·开发语言·反射·反射机制·private·类成员·反射的三大核心功能
爱吃生蚝的于勒12 分钟前
【Linux】零基础学会linux环境基础开发工具使用(yum,vim,makefile,gdb)
linux·服务器·数据结构·c++·蓝桥杯·编辑器·vim
R-G-B14 分钟前
【34】MFC入门到精通——MFC 控件 ComboBox 运行点击控件下拉框 “终止“、“重试“、“忽略“、“引发异常”
c++·mfc·combobox“引发异常”·“终止“·“重试“·“忽略“·“引发异常”
零基础的修炼25 分钟前
Linux---线程封装
linux·c++·算法
虚行34 分钟前
Python学习入门
开发语言·python·学习
给大佬递杯卡布奇诺36 分钟前
FFmpeg 基本API avio_read函数内部调用流程分析
c++·ffmpeg·音视频
总有刁民想爱朕ha38 分钟前
Python自动化从入门到实战(23):Python打地鼠游戏开发
开发语言·python·游戏开发
曹牧39 分钟前
C#:函数默认参数
开发语言·c#
黄焖鸡能干四碗1 小时前
MES生产执行制造系统建设(Java+Mysql)
java·大数据·开发语言·信息可视化·需求分析