基于锁的并发跳表:LazySkipList 类详解
1. 跳表基础操作
跳表是一种随机化的数据结构,支持高效的插入、删除和查找操作。在跳表中添加或删除节点时, find() 方法起着关键作用。
当向跳表中添加节点时, find() 方法会遍历跳表,填充 preds[] 和 succs[] 数组,分别记录目标节点在各层的前驱和后继节点。例如,要添加一个键为 12 的节点, find() 方法会从最高层开始遍历,当 curr 小于或等于目标键 12 时继续遍历,否则记录 pred 和 curr 到相应数组,并下降到下一层。如果在最低层列表中未找到键为 12 的节点, add(12) 操作就可以继续进行。添加节点时,会创建一个新节点,将其 next 引用重定向到对应的 succs[] 节点,同时将每个前驱节点的 next 引用重定向到新节点。
当从跳表中删除节点时, find() 方法同样会初始化受害者节点的 preds[] 和 succs[] 数组,然后通过重定向每个前驱节点的 next 引用到受害者节点的后继节点,将受害者节点从所有层的列表中移除。
以下是一个简单的示例,展示了
超级会员免费看
订阅专栏 解锁全文
24

被折叠的 条评论
为什么被折叠?



