c++ std::map<string,string> 是有序的吗?
Are c++ std::map<string,string> ordered?
STL映射是有序的吗?
具体来说,我需要知道是否订购了std::map。因此,如果我迭代它,它将首先使用第一个插入字符串进行迭代。
那么下面的迭代会一致地迭代 A、C 然后 B 吗?
std::map<string,string> str_map;
str_map.insert(std::make_pair("A","Data"));
str_map.insert(std::make_pair("C","Data"));
str_map.insert(std::make_pair("B","Data"));
STL地图是订购的吗?
是的,默认情况下,std::map<K,V>
是根据键排序的,K
,使用 std::less<K>
来比较对象。
因此,如果我迭代它,它会先迭代第一个插入字符串吗?
不。 它将根据排序顺序进行迭代,而不是您插入元素的顺序。 在std::string
的情况下,它按词典顺序(字母顺序)排序。
如果要根据广告顺序进行迭代,最好使用序列容器,例如std::vector
或std::list
。
std::map
使用给定类型的operator<
或使用自定义比较函数/函子(如果作为参数提供给构造函数)进行排序。
所以不,当你遍历地图时,你得到的第一个项目不会是你首先插入的项目 - 它将是按字母顺序排在第一位的项目。
当然,对于您的示例代码,这没有区别,因为"A"是您插入的第一个键,也是按字母顺序排列的第一个键。
相关文章:
- cppcheck在const std::string[]上引发警告
- 将std::string传递给WriteConsole API
- 为std::string的某个索引赋值
- std中有类似find_last_of的函数,而string中没有
- EASTL矢量<向量<int>>连续的
- 使用 std::string () const 函数启动线程或未来
- 使用char类型将decimal转换为string,将string转换为decimal
- 迭代和比较映射<字符串、矢量<string>> c++ 中的值
- 当我们进行一些操作时,应该使用什么'std::string'或'std::stringstream'?
- 将向量解析<string>为字符串
- 'string.assign(string.data(), 5)' 是明确定义的还是 UB?
- 如何更改大小(std::string)
- "string.h"在构建适用于iOS的qt应用程序中找不到消息
- C++:如何将 unix 时间的字符串转换为 *tm?(使用时间错误:"cannot convert 'String' to 'tm*' ")
- std::string 的对象真的可以移动吗?
- 与'operator='不匹配(操作数类型'String'且"void")
- SegFault 同时使用 std::string::operator+= 和函数作为参数
- 无法从 std::string 中提取C++ Unicode 符号
- std::string 构造函数如何处理固定大小的 char[]?
- <string> 使用 for 循环写入向量