VS关于hash_map使用的一些经常使用构造方法汇总,包含基本类型和结构体,相信够一般模仿使用:

# include<hash_map>
#include<iostream>
#include<string>
struct order
{
char orderNO[20];
char name[10];
int NO;
char type;
};
typedef order Order;
struct cmp{
enum
{
bucket_size=100,
};
size_t operator()(Order order1)
{
return sizeof(order1.orderNO)+sizeof(order1.name)+sizeof(order1.NO)+sizeof(order1.type);
} bool operator()(Order order1,Order order2)
{
if(strcmp(order1.orderNO,order2.orderNO)>0)
return true;
else if(strcmp(order1.orderNO,order2.orderNO)<0)
return false;
else
{
if(strcmp(order1.name,order2.name)>0)
return true;
else if(strcmp(order1.name,order2.name)<0)
return false;
else{
if(order1.NO>order2.NO)return true;
else if(order1.NO<order2.NO)return false;
else{
if(order1.type>order2.type)return true;
else return false;
}
}
}
} }; struct CharLess : public std::binary_function<const char*,const char*, bool>
{
public:
result_type operator()(const first_argument_type& _Left, const second_argument_type& _Right) const
{
return(stricmp(_Left, _Right) < 0 ? true : false)<span style="font-family: Arial, Helvetica, sans-serif;">;</span>
}
}; struct CharLess1 : public std::binary_function<char*, char*, bool>
{
public:
result_type operator()(const first_argument_type& _Left, const second_argument_type& _Right) const
{
return(stricmp(_Left, _Right) < 0 ? true : false);
}
}; void testHashMap()
{
stdext::hash_map<int,int> mhasp_map1;
for(int i=0;i<9;i++)
mhasp_map1.insert(stdext::pair<int,int>(i,i+10));
stdext::hash_map<int,int>::iterator mit1=mhasp_map1.begin();
while(mit1!=mhasp_map1.end())
{
std::cout<<mit1->first<<" "<<mit1->second<<std::endl;
mit1++;
} stdext::hash_map<const char*,std::string,std::hash_compare<const char *,CharLess> > testhash;
testhash["东方不败"]="葵花宝典,技压群雄";
testhash["西门吹雪"]="寒剑三尺,削铁如泥";
testhash["上官玉儿"]="花容月貌,一笑倾城";
stdext::hash_map<const char *,std::string,std::hash_compare<const char *,CharLess> >::iterator testhashit=testhash.begin();
while(testhashit!=testhash.end())
{
std::cout<<testhashit->first<<" "<<testhashit->second.c_str()<<std::endl;
testhashit++;
}
char a[20];
scanf("%s",a);
std::cout<<testhash.find(a)->first<<std::endl; stdext::hash_map<char *,std::string,std::hash_compare<char *,CharLess1> > testhash1;
testhash1["东方不败"]="葵花宝典。技压群雄";
testhash1["西门吹雪"]="寒剑三尺,削铁如泥";
testhash1["上官玉儿"]="花容月貌,一笑倾城";
stdext::hash_map<char *,std::string,std::hash_compare<char *,CharLess1> >::iterator testhashit1=testhash1.begin();
while(testhashit1!=testhash1.end())
{
std::cout<<testhashit1->first<<" "<<testhashit1->second<<std::endl;
testhashit1++;
} //char a[20]; scanf("%s",a);
std::cout<<testhash.find(a)->first<<std::endl;
//std::cout<<testhash1.find("东方不败")->first<<std::endl;
stdext::hash_map<std::string,std::string> testhash2;
testhash2["东方不败"]="葵花宝典,技压群雄";
testhash2["西门吹雪"]="寒剑三尺,削铁如泥";
testhash2["上官玉儿"]="花容月貌。一笑倾城";
stdext::hash_map<std::string,std::string>::iterator testhashit2=testhash2.begin();
while(testhashit2!=testhash2.end())
{
std::cout<<testhashit2->first<<" "<<testhashit2->second<<std::endl;
testhashit2++;
} scanf("%s",a);
std::string str(a);
std::cout<<testhash2.find(str)->first<<std::endl; Order order1={"SR405","小麦",100,10};
Order order2={"SR406","小麦",100,10};
Order order3={"SR406","小米",100,10};
Order order4={"SR406","小米",101,10};
Order order5={"SR406","小米",101,11};
stdext::hash_map<Order,std::string,cmp> teststruct;
teststruct.insert(std::pair<Order,std::string>(order1,"sr112"));
teststruct.insert(std::pair<Order,std::string>(order2,"sr113"));
teststruct.insert(std::pair<Order,std::string>(order3,"sr114"));
teststruct.insert(std::pair<Order,std::string>(order4,"sr115"));
teststruct.insert(std::pair<Order,std::string>(order5,"sr116"));
stdext::hash_map<Order,std::string,cmp>::iterator it;
it=teststruct.find(order1);
std::cout<<it->second<<std::endl;
g<span style="font-family: Arial, Helvetica, sans-serif;">etchar();</span>
}
int main()
{
testHashMap();
getchar();
}

假设有不明白的地方。请參考博客:http://blog.csdn.net/sdhongjun/article/details/4517325,这位大神写的比較具体,细致看看。

VS2012关于hash_map的使用简略的更多相关文章

  1. VS2012+EF6+Mysql配置心路历程

    为了学习ORM,选择了EntityFramework,经历了三天两夜的煎熬,N多次错误,在群里高手的帮助下,终于成功,现在将我的心路历程记录下来,一是让自己有个记录,另外就是让其它人少走些弯路. 我的 ...

  2. VS2010 VS2012 VS2013 VS2015启动调试时老是提示正在下载公共符号

    VS2010 VS2012 VS2013 VS2015启动调试时老是提示正在下载公共符号,下载一些.dll文件,点取消后也能继续调试,但特别慢.解决方法:工具-选项,或者调试-选项和设置,将调试下的& ...

  3. VS2012程序打包部署详解

    VS2012没有自带打包工具,所以要先下载并安装一个打包工具.我采用微软提供的打包工具:  InstallShield2015LimitedEdition.下载地址:https://msdn.micr ...

  4. 从网上找的 visual studio 的各个版本下载地址,vs2010/vs2012/vs2013带注册码

    从网上找的 visual studio 的各个版本下载地址,很全,从 6.0 一直 到 vs2013,要的拿去吧... Microsoft Visual Studio 6.0 下载:英文版360云盘下 ...

  5. VS2012 Unit Test 个人学习汇总(含目录)

    首先,给出MSDN相关地址:http://msdn.microsoft.com/en-us/library/Microsoft.VisualStudio.TestTools.UnitTesting.a ...

  6. VS2012 Unit Test —— 我对IdleTest库动的大手术以及对Xml相关操作进行测试的方式

    [1]我的IdleTest源码地址:http://idletest.codeplex.com/ [2]IdleTest改动说明:2013年10月份在保持原有功能的情况下对其动了较大的手术,首先将基本的 ...

  7. VS2012 Unit Test——Microsoft Fakes入门

    如题,本文主要作为在VS2012使用Fakes的入门示例,开发工具必须是VS2012或更高版本. 关于Fakes的MSDN地址:http://msdn.microsoft.com/en-us/libr ...

  8. 在Qt Creator 和在 vs2012 里添加信号和槽

    原文地址:http://www.cnblogs.com/li-peng/p/3644812.html 作者:李鹏 出处:http://www.cnblogs.com/li-peng/ 本文版权归作者和 ...

  9. vs2012 安装entity framework

    1.安装vs2012 2.打开vs2012的工具下的扩展工具 3.搜索nuget,没安装的直接在线安装 4.安装好了NuGet,程序包管理器控制台 5.执行命令Install-Package Enti ...

随机推荐

  1. 数据库_11_1~10总结回顾+奇怪的NULL

    校对集问题: 比较规则:_bin,_cs,_ci利用排序(order by) 另外两种登录方式: 奇怪的NULL: NULL的特殊性:

  2. Java垃圾回收之新生代垃圾收集器

    问题:什么是Stop-the-World? 1.JVM由于要执行GC而停止了应用程序的执行 2.任何一种GC算法中都会发生 3.多数GC优化通过减少Stop-the-world发生的时间来提高程序的性 ...

  3. 【mybatis】mybatis数据源源码剖析(JNDI、POOLED、UNPOOLED)

    一.概述 二.创建 mybatis数据源的创建过程稍微有些曲折. 1. 数据源的创建过程: 2. mybatis支持哪些数据源,也就是dataSource标签的type属性可以写哪些合法的参数? 弄清 ...

  4. Brackets POJ - 2955

    解法 区间dp例题,每次枚举分段点的时候先更新如果开始到结束区间端点有闭合的括号,那么dp[start][end]=dp[start+1][end-1]+2其他照常枚举即可 代码 #include & ...

  5. CTSC1998 选课(背包类树形Dp)

    题意: 给出 n 节课的先修课号以及学分(先修课号指的是在学习某节课时先需要学习的课程),求学 m 节课的最大学分. 细节: 1.对于课程 a 其先修课号为 b ,对于课程 b 其先修课号为 c ,则 ...

  6. sysctl.conf文件配置详解

    ############################# net.inet.ip.sourceroute=0 net.inet.ip.accept_sourceroute=0 ########### ...

  7. java环境配置——工具下载地址

    每次官网找个下载地址都是 费劲巴拉的 整理了一下几个下载地址分享给大家 eclipse:http://www.eclipse.org/downloads/packages/release/Kepler ...

  8. N个数求和(模拟)

    本题的要求很简单,就是求N个数字的和.麻烦的是,这些数字是以有理数分子/分母的形式给出的,你输出的和也必须是有理数的形式. 输入格式: 输入第一行给出一个正整数N(≤100).随后一行按格式a1/b1 ...

  9. 使用jemalloc优化nginx和mysql内存管理

    预先安装autoconf 和 make yum -y install autoconf make jemalloc的安装jiemalloc 开源项目网站 http://www.canonware.co ...

  10. python中的“坑”—持续更新

    1.判断是否是回文 def is_back(s): ]==(s if s.strip() else False) print(is_back('上海自来水来自海上')) print(is_back(' ...