我正在尝试为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等。非常感谢您的见解。
答案 0 :(得分:13)
直接尝试使用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'。