0

0

C++怎么实现一个简单的线程安全哈希表_C++使用分段锁或读写锁优化并发性能

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-11-24 11:47:02

|

373人浏览过

|

来源于php中文网

原创

线程安全哈希表可通过互斥锁、读写锁或分段锁实现;低并发用mutex,读多写少用shared_mutex,高并发推荐分段锁以降低竞争,提升性能。

c++怎么实现一个简单的线程安全哈希表_c++使用分段锁或读写锁优化并发性能

实现一个线程安全的哈希表,核心是在并发访问时保护数据不被破坏。C++中可以通过互斥锁(mutex)、读写锁(shared_mutex)或分段锁(striped locking)来控制对桶(bucket)的访问。为了提升性能,避免全局锁成为瓶颈,可以采用分段锁或读写锁机制。

使用标准互斥锁的简单线程安全哈希表

最直接的方式是为整个哈希表加一把互斥锁。虽然实现简单,但在高并发下性能较差,因为所有操作都串行化。

#include 
#include 

template
class ThreadSafeHashMap {
private:
    std::unordered_map map_;
    mutable std::mutex mtx_;

public:
    void put(const K& key, const V& value) {
        std::lock_guard lock(mtx_);
        map_[key] = value;
    }

    V get(const K& key) const {
        std::lock_guard lock(mtx_);
        auto it = map_.find(key);
        return it != map_.end() ? it->second : V{};
    }

    bool remove(const K& key) {
        std::lock_guard lock(mtx_);
        return map_.erase(key) > 0;
    }
};

这个版本适合低并发场景。但当读多写少时,每次读操作也需独占锁,效率低下。

使用读写锁提升读性能

在读操作远多于写操作的场景下,使用 std::shared_mutex(C++17 起支持)能显著提升性能。读操作共享锁,写操作独占锁。

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

#include 
#include 

template
class ThreadSafeHashMapRW {
private:
    std::unordered_map map_;
    mutable std::shared_mutex rw_mutex_;

public:
    void put(const K& key, const V& value) {
        std::unique_lock lock(rw_mutex_);
        map_[key] = value;
    }

    V get(const K& key) const {
        std::shared_lock lock(rw_mutex_);
        auto it = map_.find(key);
        return it != map_.end() ? it->second : V{};
    }

    bool remove(const K& key) {
        std::unique_lock lock(rw_mutex_);
        return map_.erase(key) > 0;
    }
};

多个线程可同时进行 get 操作,只有 putremove 会阻塞彼此和其他操作。适用于缓存、配置中心等读密集型应用。

使用分段锁减少锁竞争

进一步优化,可以将哈希表分成多个段(segment),每段有自己的锁。这样不同段的操作可以并发执行,降低锁争用。

知识画家
知识画家

AI交互知识生成引擎,一句话生成知识视频、动画和应用

下载

常见做法是创建一个固定大小的锁数组,通过哈希值映射到某个锁。

#include 
#include 
#include 
#include 
#include 

template
class StripedHashMap {
private:
    std::vector> buckets_;
    std::vector locks_;

    size_t hash_to_segment(const K& key) const {
        return std::hash{}(key) % N;
    }

public:
    StripedHashMap() : buckets_(N), locks_(N) {}

    void put(const K& key, const V& value) {
        size_t seg = hash_to_segment(key);
        std::unique_lock lock(locks_[seg]);
        buckets_[seg][key] = value;
    }

    V get(const K& key) const {
        size_t seg = hash_to_segment(key);
        std::shared_lock lock(locks_[seg]);
        auto it = buckets_[seg].find(key);
        return it != buckets_[seg].end() ? it->second : V{};
    }

    bool remove(const K& key) {
        size_t seg = hash_to_segment(key);
        std::unique_lock lock(locks_[seg]);
        return buckets_[seg].erase(key) > 0;
    }
};

这种设计将锁的粒度从整个表缩小到每个桶,显著提升并发吞吐量。N 通常取 16 或 32,需根据实际并发量调整。

总结与建议

线程安全哈希表的实现应根据使用场景选择合适的同步策略:

  • 低并发或简单场景:使用单个 mutex 即可。
  • 读多写少:优先使用 shared_mutex,提高读并发。
  • 高并发写操作:采用分段锁,分散锁竞争。

注意异常安全和拷贝语义。get 返回值时若键不存在,应明确处理(抛异常或返回 optional)。更健壮的实现可返回 std::optional 而非默认构造值。

基本上就这些。合理选择锁策略,能在保证线程安全的同时获得不错的性能表现。

相关文章

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

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

下载

相关标签:

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

相关专题

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

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

476

2023.08.10

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

60

2026.01.09

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

61

2026.01.08

java学习网站汇总
java学习网站汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.01.08

正则表达式 删除
正则表达式 删除

本专题整合了正则表达式删除教程大全,阅读专题下面的文章了解更多详细教程。

55

2026.01.08

java 元空间 永久代
java 元空间 永久代

本专题整合了java中元空间和永久代的区别,阅读专题下面的文章了解更多详细内容。

4

2026.01.08

java 永久代和元空间
java 永久代和元空间

本专题整合了java中元空间和永久代的区别,阅读专题下面的文章了解更多详细内容。

0

2026.01.08

java成品网站源码资源大全
java成品网站源码资源大全

本专题整合了java成品网站源码相关内容,阅读专题下面的文章了解更多详细内容。

31

2026.01.08

java过滤器教程大全
java过滤器教程大全

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

10

2026.01.08

热门下载

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

精品课程

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

共94课时 | 6.3万人学习

C 教程
C 教程

共75课时 | 3.9万人学习

C++教程
C++教程

共115课时 | 11.6万人学习

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

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