Mam std::unordered_multimap
i chcę uzyskać ostatni wstawiony element określonego klucza. Zauważyłem ten problem:Czy mogę polegać na kolejności nieuporządkowanej mapy?
#include <iostream>
#include <string>
#include <unordered_map>
using namespace std;
int main() {
unordered_multimap<string, string> mmap;
mmap.emplace("a", "first");
mmap.emplace("a", "second");
mmap.emplace("a", "last");
mmap.emplace("b", "1");
mmap.emplace("b", "2");
mmap.emplace("b", "3");
auto last_a = mmap.equal_range("a").first;
auto last_b = mmap.equal_range("b").first;
cout << last_a->second << endl;
cout << last_b->second << endl;
return 0;
}
Ten kod wyjścia:
last
3
to przynajmniej na GCC, zachowanie chcę. Czy mogę na tym polegać? Czy standard mówi jednoznacznie o porządku przechowywania rzeczy? Jeśli nie, jaka byłaby najlepsza alternatywa?
Otrzymasz 'first 1' z [libC++] (http://coliru.stacked-crooked.com/a/f8f56abb25674bbe). –