C++编程-使用rw_hashmap实现hashmap一例

2024-04-20 00:18

本文主要是介绍C++编程-使用rw_hashmap实现hashmap一例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      目前网上能搜索到的关于C++中实现hashmap的例子很少,今天斗胆来个例子,供初学STL的人一览。
      STL中目前还没有hashmap的实现,这里使用的rw_hashmap是Rogue wave的实现.不过它已经集成到sgi stl中。我在HP-UX B.11.23中看到aCC编译器已经将其集成进来。
      言归正传,rw_hashmap的原型如下:
      rw_hashmap<K,V,Hash,EQ,Allocator> map;
      其中K为key,V为value,Hash为hash函数,EQ为key值等号重载,Allocator为分配器。
  我这里实现的是K->string,V->int.
      1.设计第三个参数Hash
              Hash必须提供一个在类型K的元素上进行hash的public函数:unsigned long operator()(const K& x) const;
              这里使用ELF hash函数:
             #include <rw/tvhdict.h>
             #include <rw/cstring.h>
             #include <utility>
              #include <iostream>
              using namespace std;

             //  ELF Hash Function
            inline unsigned  long  ELFHash(const char   * str)
             {
                       unsigned  int  hash  =   0 ;
                      unsigned  int  x     =   0 ;

                       while  ( * str)
                       {
                                 hash  =  (hash  <<   4 )  +  ( * str ++ );
                                 if  ((x  =  hash  &   0xF0000000L )  !=   0 )
                                 {
                                         hash  ^=  (x  >>   24 );
                                        hash  &=   ~ x;
                                 }
                       }

         return  (hash  &   0x7FFFFFFF );
         }
      
      class ELF_HASH{
        public:
                unsigned long operator()(const std::string& x) const
                {
                     return ELFHash(x.c_str());
                 }
          };
       
      2.设计第四个参数EQ:
               EQ需要如下public函数:bool operator()(const K& x, const K& y) const;当x与y相等时返回true.         
              class STRING_EQUAL{
               public:
                     bool operator()(const string& x, const string& y) const
                     {
                               return (x==y);
                     }
                  };      
         3.现在可以完整的定义了:
          typedef rw_hashmap<string,int,ELF_HASH,STRING_EQUAL,std::allocator<pair<string,int> > > mapDictNameId;
          4.下面是测试代码,有点粗糙,主要是从一堆代码的类中提出来的,懒得继续封装:
         mapDictNameId m_mapDictNameId;
         typedef mapDictNameId::iterator Iterator;
         typedef mapDictNameId::value_type Value_type;

void setNameKey(const string& sFieldName, int nId)
{
    string sTemp = sFieldName;
    m_mapDictNameId.insert(Value_type(sTemp, nId));
    return;
}

int getIdByName(const string& sFieldName)
{
    string sTemp = sFieldName;
    Iterator iter2;
    iter2 = m_mapDictNameId.find(sTemp);
    if (iter2 != m_mapDictNameId.end())
   {
       return (*iter2).second;
   }
  else
       return -1;
}

int main()
{
        setNameKey("NAME1",10);
        setNameKey("NAME2",11);
        int id;
        id=getIdByName("NAME1");
        cout<<"id:"<<id<<endl;                 
}

输出结果为:
          id:10

这篇关于C++编程-使用rw_hashmap实现hashmap一例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/918826

相关文章

Python中Tkinter GUI编程详细教程

《Python中TkinterGUI编程详细教程》Tkinter作为Python编程语言中构建GUI的一个重要组件,其教程对于任何希望将Python应用到实际编程中的开发者来说都是宝贵的资源,这篇文... 目录前言1. Tkinter 简介2. 第一个 Tkinter 程序3. 窗口和基础组件3.1 创建窗

利用c++判断水仙花数并输出示例代码

《利用c++判断水仙花数并输出示例代码》水仙花数是指一个三位数,其各位数字的立方和恰好等于该数本身,:本文主要介绍利用c++判断水仙花数并输出的相关资料,文中通过代码介绍的非常详细,需要的朋友可以... 以下是使用C++实现的相同逻辑代码:#include <IOStream>#include <vec

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

C#中checked关键字的使用小结

《C#中checked关键字的使用小结》本文主要介绍了C#中checked关键字的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录✅ 为什么需要checked? 问题:整数溢出是“静默China编程”的(默认)checked的三种用

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

C#中预处理器指令的使用小结

《C#中预处理器指令的使用小结》本文主要介绍了C#中预处理器指令的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 第 1 名:#if/#else/#elif/#endif✅用途:条件编译(绝对最常用!) 典型场景: 示例

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

SpringBoo WebFlux+MongoDB实现非阻塞API过程

《SpringBooWebFlux+MongoDB实现非阻塞API过程》本文介绍了如何使用SpringBootWebFlux和MongoDB实现非阻塞API,通过响应式编程提高系统的吞吐量和响应性能... 目录一、引言二、响应式编程基础2.1 响应式编程概念2.2 响应式编程的优势2.3 响应式编程相关技术