我正在尝试为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’.