map 和 unordered_map 容器提供了下标运算符。学习数据结构时用到了这个知识点,忽而意识到下标运算符好处,特此复习梳理。
对于一个map使用下标运算符,其行为与数组或vector上下标操作很不同。使用一个不在容器中的关键字作为下标,会添加一个具有此关键字的元素到map中。
例:c[k] 返回关键字为k的元素;如果k不在c当中,添加一个关键字为k的元素,对其进行值初始化。
通常情况下,解引用一个迭代器返回的类型与下标运算符返回的类型相同,但对于map进行下标操作时,会获得一个mapped_type对象;但当解引用map迭代器时,返回value_type对象。
因此,如果关键字不在map中,下标操作符会添加一个新元素。但如果只是想知道一个元素是否在map中,不存在时并不想添加元素,则使用find。