To get a bimap between size_t and std::string where you have ~constant (up to the cost of hashing and any potential clashes) you need to use unordered_set_of:
#include <boost/bimap.hpp>
#include <boost/bimap/unordered_set_of.hpp>
#include <string>
#include <iostream>
#include <typeinfo>
int main(int argc, char* argv[]) {
typedef boost::bimap< boost::bimaps::unordered_set_of<size_t>, boost::bimaps::unordered_set_of<std::string> > StringMap;
StringMap map;
map.insert(StringMap::value_type(1,std::string("Cheese")));
map.insert(StringMap::value_type(2,std::string("Cheese2")));
typedef StringMap::left_map::const_iterator const_iter_type;
const const_iter_type end = map.left.end();
for ( const_iter_type iter = map.left.begin(); iter != end; iter++ ) {
std::cout << iter->first << " " << map.left.at(iter->first) << "\n";
}
}
returns:
1 Cheese
2 Cheese2
The unordered_set is a boost version of set which uses hash tables instead of trees to store the elements, see Boost Unordered docs.
Looking at the comments from one of the bimap examples at Bimap example, we have:
The left map view works like a std::unordered_map< std::string, long >,
given the name of the country we can use it to search for the population in constant time
size_t
andstring
objects with O(1) access time for both and minimal or modest memory requirements. – Uncovered