0

0

C++如何实现一个支持多线程并发读写的自适应跳表?(高性能索引设计)

冰火之心

冰火之心

发布时间:2026-03-04 12:54:12

|

217人浏览过

|

来源于php中文网

原创

跳表多线程下不能仅用std::shared_mutex,因其写操作需跨层级修改且路径不固定;应采用分段锁+无锁读,每段配mutex,读用原子指针与acquire内存序。

c++如何实现一个支持多线程并发读写的自适应跳表?(高性能索引设计)

为什么跳表在多线程下不能直接加锁 std::shared_mutex 就完事?

因为跳表的写操作(插入/删除)会修改多个层级的指针,且路径不固定——你锁住某个节点,不代表它前驱或后继节点没被其他线程同时修改。用 std::shared_mutex 全局读写锁会导致读吞吐骤降;只锁单个节点又无法保证结构一致性。

真正可行的路是「分段锁 + 无锁读」:把跳表按 key 范围切分成若干段(比如 64 段),每段配一把 std::mutex,写操作只锁涉及的段;读操作则全程无锁,靠原子指针和内存序保障可见性。

  • 段数太少 → 锁竞争高;太多 → cache line false sharing 和管理开销上升
  • key 分段不能用取模(hash(key) % N),得用高位截断(如 (uint64_t)key >> 48),避免哈希碰撞集中
  • 读操作必须用 std::memory_order_acquire 加载指针,否则可能看到未完成的中间状态

std::atomic 指针怎么安全地更新跳表层级指针?

跳表每个节点的 next 是个指针数组,但 C++ 不允许对数组做原子操作。常见错误是把整个 next[] 声明为 std::atomic<node></node> 数组——这不合法,编译不过。

正确做法是:每个层级的指针单独声明为 std::atomic<node></node>,例如 std::atomic<node> next[LEVEL_MAX]</node>。更新时逐层 CAS(Compare-And-Swap),并确保高层更新前,低层已稳定。

立即学习C++免费学习笔记(深入)”;

云雀语言模型
云雀语言模型

云雀是一款由字节跳动研发的语言模型,通过便捷的自然语言交互,能够高效的完成互动对话

下载
  • CAS 失败不等于失败:可能是别人刚改了同一层,需重试;但若发现某低层指针变为空,说明节点正被删除,应中止当前插入
  • 层级高度必须在插入前就确定(如通过随机数),不能边走边生成,否则无法保证多线程下结构可预测
  • 所有 std::atomic 操作必须显式指定内存序:load()acquirestore()releasecompare_exchange_weak() 默认是 acq_rel

自适应层级(adaptive level)到底该响应什么信号?

所谓“自适应”,不是指运行时动态调整整个跳表的 LEVEL_MAX,而是针对每个新插入节点,根据当前负载实时决定其高度。关键信号只有两个:size() 和最近一次 GC 的碎片率。

别被论文带偏——不需要复杂反馈控制。实践中有效策略是:当总节点数超过 1 且最近删除密度 > 30%,就将新节点初始高度 +1(上限仍为 <code>LEVEL_MAX)。

  • 不要用系统时间或线程 ID 做随机源,thread_local std::mt19937 更可靠
  • 高度提升是“倾向性”而非强制:仍以概率 1/4 决定是否升层,只是基础概率从 0.5 调到 0.75
  • 层级过高(>32)反而降低缓存局部性,LEVEL_MAX 设为 24 是 x86-64 下实测较优值

并发读写下如何避免 ABA 问题导致的节点悬挂?

跳表删除节点时,若仅靠 CAS 把前驱的 next[i] 从 A 改成 B,而 A 被释放后内存又被分配给新节点 A',下次 CAS 可能误判成功——这就是 ABA。C++ 标准库的 std::atomic<t>::compare_exchange_weak</t> 本身不防 ABA。

解决方案不是引入 std::atomic<uintptr_t></uintptr_t> 手动拼地址+版本号(太重),而是复用节点内存池 + hazard pointer。每个线程维护一个 hazard_ptr 数组,读操作开始前把正在访问的节点指针存进去;删除线程只回收那些没被任何 hazard_ptr 引用的节点。

  • hazard pointer 数组大小设为 4 即可覆盖 99% 场景,再多是浪费
  • 必须配合惰性回收:删除标记后不立即 free,等所有线程都完成一次 quiescent state(比如遍历完一次跳表)再批量回收
  • 别忘了在析构函数里调用 hazard_thread_retire(),否则进程退出时内存泄漏

最易被忽略的一点:hazard pointer 的存储位置必须是 thread_local,且初始化要早于任何跳表操作——晚了会导致首次读就 crash。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

374

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

27

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

102

2026.02.06

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

5

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

11

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

33

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

25

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.6万人学习

C 教程
C 教程

共75课时 | 5.2万人学习

C++教程
C++教程

共115课时 | 20.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号