我是靠谱客的博主 俊秀羽毛,最近开发中收集的这篇文章主要介绍C++ map查找key时注意事项,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1、在map中,由key查找value时,首先要判断map中是否包含key。

2、如果不检查,直接返回map[key]可能出现意想不到的行为。如果map包含key,没有问题,如果map不包含key,使用下标有一个危险的副作用,会在map中插入一个key的元素,value取默认值,返回value。也就是说,map[key]不可能返回null。

3、map提供两种方法来检查,是否包含key,m.count(key) , m.find(key).

4、m.count(key):由于map不包含重复的key,因此m.count(key)取值为0,或者1,表示是否包含。

5、m.find(key):返回迭代器,判断是否存在。

6、对于下面的场景,存在key就使用,否则返回null,有下面两种写法:

1 if(m.count(key)>0)
2 {
3     return m[key];
4 }
5 return null;
1 iter = m.find(key);
2 if(iter!=m.end())
3 {
4     return iter->second;
5 }
6 return null;
这里需要注意:前一种方法很直观,但是效率差很多。因为前面的方法,需要执行两次查找。因此,推荐使用后一种方法。

7、对于STL中的容器,有泛型算法find(begin,end,target)查找目标,map还提供了一个成员方法find(key)。

文章来源:https://blog.csdn.net/wangjingqi930330/article/details/81938998。感谢下一站——浮华。

最后

以上就是俊秀羽毛为你收集整理的C++ map查找key时注意事项的全部内容,希望文章能够帮你解决C++ map查找key时注意事项所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部