为什么无法使用反向迭代器从 std::map 中删除元素
Why is it not possible to remove elements from a std::map using reverse iterators?
我一直在寻找最有效和最具表现力的方法来从std::map
中删除最后一个元素。我试过了:
#include <map>
int main()
{
std::map<int, int> m;
m.insert(std::make_pair(1,1));
m.erase(m.crbegin());
return 0;
}
代码无法编译,因为std::map::erase
只能std::map::const_iterator
此外,在 C++11 之前,它也可能需要 std::map::iterator
秒,但由于某种原因,此功能也被删除了。
这些限制背后的动机是什么?
erase()
现在需要const_iterator
s才能使const_iterator
真正有用。 iterator
可转换为const_iterator
,因此原始功能不受影响。
reverse_iterator
是一个迭代器适配器;它公开一个 .base()
成员函数以获取基础迭代器,您可以将其传递给容器成员函数。也就是说,crbegin().base()
是end()
,end()
传递给erase()
是UB。
相关文章:
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 使用一个考虑到std::map中键值的滚动或换行的键
- 有没有办法对std::unordered_set、std::unrdered_map、std::set、std::map
- 将重物插入std::map
- 使用通用值初始化 std::map,不重复
- 仅包含可移动 std::map 的类的移动构造函数不起作用
- C++:当所有条目都保证是唯一时,替代 std::map
- 使用模板化的键类型定义 std::map,该键类型基于作为参数接收的函数
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?
- C++如何创建 std::map
- 从其他容器中移动构造"std::map"
- 将 std::map::emplace 与返回 shared_ptr 的函数一起使用是否正确?
- C++中 std::map 的运行时复杂度是多少?
- 为什么在 std::map 上移动无法将元素从一个映射移动到另一个映射
- 使用重载 [] 运算符返回 std::map() 的可赋值
- std::map, std::unordered_map - 缩小初始值设定项列表中的转换范围
- C++ 使用枚举类对象分配 std::map 值
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- std::map:当元素不可默认构造时创建/替换元素
- Arduino编译器和STL:使用std::vector和std::map