自定义“准线程安全”与“线程安全”的unordered_map泛型基类

本文介绍了一个自定义的准线程安全的unordered_map泛型基类,只在修改元素数量时加锁,适用于读取操作频繁、写入操作不频繁的场景。该基类提供了增删查改等常用操作,并通过示例展示了其使用方法。
摘要由CSDN通过智能技术生成

准线程安全:map中原素个数改变才加锁,适合读频繁,写不频繁的情况;

 


#include"mutex"
#include"unordered_map"

template<typename K,typename V>
class dict_safe_base
{
private:
    std::unordered_map<K,V> _map;
    std::mutex _mutex;
public:
    dict_safe_base()
    {
    }

    std::vector<V> visit(std::function<std::vector<V>(const std::unordered_map<K,V>&)> visitor_fun)
    {
        std::lock_guard<std::mutex> lock(_mutex);

        return visitor_fun(_map);
    }

    V get(K& k)
    {
        std::lock_guard<std::mutex> lock(_mutex);

        auto serch = _map.find(k);
        return (_map.end()!=serch) ? serch->second : nullptr;
    }

    void add(K& k, V& v)
    {
        std::lock_guard<std::mutex> lock(_mutex);

        _map.insert({k,v});
    }

    void add(const std::unordered_map<K,V>& m)
    {
        std::lock_guard<std::mutex> lock(_mutex);

        _map.insert(m.begin(), m.end());
    }

    void add_replace(K& k, V& v)
    {
        std::lock_guard<std::mutex&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值