没有躲过的坑--map查找结果处理
来源:互联网 发布:万人网络信息有限公司 编辑:程序博客网 时间:2024/06/16 08:36
通过键-值的方法进行搜索,可以使用map,极大的提高了速度。
下面代码就是使用map的find查找,通过键,找出对应的值。
map<std::string, int> string_int_map;//对string_int_map进行初始化map<std::string, int >::iterator iter_string_int; string substring_to_find = ":who call who:";iter_string_int = string_int_map.find(all_emoji_string[i]);int result = iter_string_int ->second;
还是,上面的程序大多数情况下没问题,但是我没有考虑万一map中不存在我们查找的键呢?
再看了一下find函数的返回值:
引用具有指定键的元素的位置的迭代器,如果找不到具有键的匹配项,则引用映射中 (map::end()) 最后一个元素后面的位置。
如果你没考虑这个,那么当返回map::end()后:
iter_string_int ->second;
这个指向超尾的迭代器的second和first又是什么?
写个小程序测试一下:
#include<iostream>#include<map>int main(){ std::map<std::string, int> test_map = { {"how", 3}, {"are", 4}, {"you", 5} }; std::map<std::string, int >::iterator iter_string_int; std::string key_string = "shit"; iter_string_int = test_map.find(key_string); std::cout << iter_string_int->second << std::endl; return 0;}
运行:
崩溃。
这是在控制台程序中,编译器会温柔的给你提示。
但是在一个大型的win32程序中,就不会这么轻易的给你提示了。
所以 我们要判断find函数的返回值:
find的返回值不等于map::end(),才可以往下进行操作。
#include<iostream>#include<map>int main(){ std::map<std::string, int> test_map = { {"how", 3}, {"are", 4}, {"you", 5} }; std::map<std::string, int >::iterator iter_string_int; std::string key_string = "shit"; iter_string_int = test_map.find(key_string); if(iter_string_int == test_map::end()) { std::cout << "error" << endl; } else { std::cout << iter_string_int->second << std::endl; } return 0;}
1 0
- 没有躲过的坑--map查找结果处理
- 没有躲过的坑--map的初始化(插入数据)
- 没有躲过的坑--deprecated关键字
- 没有躲过的坑--智能指针陷阱
- 没有躲过的坑--重定义关键字
- 没有躲过的坑--没有及时break出for循环
- 没有躲过的坑--wstring与string的转换
- 没有躲过的坑--正确释放vector的内存
- 没有躲过的坑--意想不到的除数为零
- 没有躲过的坑--使用太多的全局变量
- 那些年没有躲过的Appium的坑
- 没有躲过的坑--指针(内存泄露)
- 没有躲过的坑--string中的c_str()陷阱
- 没有躲过的坑--获取设备环境HDC
- 没有躲过的坑--程序中的变量未初始化
- 没有躲过的坑--正则表达式截取字符串
- 没有躲过的坑--获取一张图片的width和height
- 没有躲过的坑--重载赋值运算符的自我赋值
- 学习Struts2_0400_path
- 矩阵论:同一个线性变换在新基、旧基下表示成不同矩阵的关系
- Spring调度 Quartz实现
- 利用数组实现直接插入排序
- 在struts2中防止表单的重复的提交
- 没有躲过的坑--map查找结果处理
- 树莓派安装Linux操作系统
- STM32学习第二天---初步了解了一些方便的位运算
- html 界面 添加 百度地图
- 数组的基本操作(五)
- 还是操作系统试题
- 从大数据菜鸟走上大师的历程 Scala 第六讲 Map Zip
- 分辨率、像素、密度和屏幕尺寸的关系(换算)
- poj2253 Dijkstra