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

本文主要围绕C++中map与set展开,介绍了它们都继承自父类_Tree,父类红黑树操作具有通用性。阐述了set节点的数据结构及泛型推导过程,还说明了在红黑树中查找节点的方式,指出map和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源码分析。那个是第一遍做的。谢谢,感恩一切。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangzhangkeji

谢谢支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值