C++ map find() 盲区

环境:Win10 x64,VS2017

介绍:C++ std::map 容器使用 find 函数

记录时间:2020/08/27


内容:

平常习惯用std::vector 容器,std::vector<class T> find 调用的是 T的operation == 函数

但std::map<class T, ....> find 调用的却是T的operation < 函数,这个一定要注意 !!!


个人办法

如何使用map 中的find() 呢?

1. 使用STL中 std::find_if(), 并自定义Key 类型的operation== 重载函数

例如:

std::map<Class A,Class B> mapData;

A taget;

个人习惯用STL库

std::find_if(mapData.begin(),mapData.end(),[taget](std::pair<Class A,Class B> obj){return obj.first == target; }) != mapData.end()

原因是判断对象是否相等更好写!

2. 重载Key 类型的operation< 函数, 这肯定是标准做法,但要避免参数遗漏,

有的时候判断对象是否小于可能会把自己绕进去......


补充:

std::map 使用时有些缺陷,如:

1. 自动排序

2. 查找 使用 operation <

3. 有时还会遇到奇怪的错误

所以如果是基础类型int,double,string 等可以用map 做Key,

如果是自定义类型且结构较为复杂,建议使用vector代替。

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值