我正在尝试为C中的枚举创建一个简单的双向查找工具.我的单向查找工作正常……
enum MyEnum { One,Two,Three }; const boost::unordered_map<MyEnum,std::string> MyEnumMap = map_list_of (One,"One") (Two,"Two") (Three,"Three");
然后看看
MyEnumMap.at(One)
这有效,但它只允许基于密钥的查找.我想使用一个双向查找容器,如boost:bimap,以便根据值和键进行简单的反向查找.尽管如此,map_list_of似乎与boost :: bimap不兼容.
首先,我是否还应该使用带有boost :: bimap的map_list_of,还是需要另一种类型?
这些地图都是基本的(枚举,字符串)类型.
第二,有没有一种方法我仍然可以像上面那样以简单的方式将地图定义为const?我试图让这个更容易更新和维护,而不会进入太多额外的typedef等.非常感谢您的见解.
解决方法
尝试直接使用list_of:
typedef boost::bimap< MyEnum,std::string > bm_type; const bm_type MyEnumMap = boost::assign::list_of< bm_type::relation > ( One,"One" ) ( Two,"Two" ) ( Three,"Three" );
请注意’relation’的使用而不是’value_type’.