关联容器的下标操作

map 和 unordered_map 容器提供了下标运算符。学习数据结构时用到了这个知识点,忽而意识到下标运算符好处,特此复习梳理。

对于一个map使用下标运算符,其行为与数组或vector上下标操作很不同。使用一个不在容器中的关键字作为下标,会添加一个具有此关键字的元素到map中。

例:c[k] 返回关键字为k的元素;如果k不在c当中,添加一个关键字为k的元素,对其进行值初始化。

通常情况下,解引用一个迭代器返回的类型与下标运算符返回的类型相同,但对于map进行下标操作时,会获得一个mapped_type对象;但当解引用map迭代器时,返回value_type对象。

因此,如果关键字不在map中,下标操作符会添加一个新元素。但如果只是想知道一个元素是否在map中,不存在时并不想添加元素,则使用find。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值