Ho un std::unordered_multimap
e voglio ottenere l'ultimo elemento inserito di una chiave specifica. Ho osservato questo comportamento:Posso fare affidamento sull'ordine di una mappa non ordinata?
#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;
}
Questo uscite di codice:
last
3
Questo è, almeno, il GCC, il comportamento che voglio. Posso fare affidamento su questo? Lo standard dice simething sull'ordine che le cose del negozio std::unordered_multimap
memorizzano? In caso contrario, quale sarebbe l'alternativa migliore?
Otterrai 'primo 1' con [libC++] (http://coliru.stacked-crooked.com/a/f8f56abb25674bbe). –