2

目标:带有字符串键的标准映射模板 + 用于区分大小写的可选真/假参数

让它按如下方式工作,但结果很丑 - 必须有更好的方法!

//step 1: templated typdefs for case-insensitive (ci), case-sensitive (cs) maps
template <typename T> struct ci_map { typedef std::map<std::string, T, ci_compare_string> type; }; //ci version
template <typename T> struct cs_map { typedef std::map<std::string, T                   > type; }; //cs version

//step 2: a template specialized to select on the of the two versions
template<typename T, bool ci> struct map_choice           {                                }; //empty decl
template<typename T>          struct map_choice<T, true>  { typedef ci_map<T> map_version; }; //specialize ci = true
template<typename T>          struct map_choice<T, false> { typedef cs_map<T> map_version; }; //specialize ci = false

//final step, but VS 2008 compile error: 'map_choice<T,ci>::map_version::type': dependent name is not a type
template<typename T, bool ci=true> 
struct mymap { typedef map_choice<T, ci>::map_version::type type; };
//too bad ... usage would have been concise ==>  "mymap<int>::type  mymap_instance;"

//final step: works, but ugly
template<typename T, bool ci=true> 
struct mymap { typedef map_choice<T, ci> type; };
//usage (ugly !!!)
mymap<int>::type::map_version::type    mymap_instance;  //ouch

有什么改进建议吗?

4

2 回答 2

2
template<typename T, bool ci=true> 
struct mymap { typedef typename map_choice<T, ci>::map_version::type type; };

Will work fine. Read: Where and why do I have to put the "template" and "typename" keywords?

于 2013-02-21T13:07:10.740 回答
2

这个怎么样:

template <bool ci>
struct Comparator
{
  typedef ci_compare_string type;
};

template<>
struct Comparator<false>
{
  typedef std::less<std::string> type;
};


template <typename T, bool ci = true>
struct mymap
{
  typedef std::map<std::string, T, typename Comparator<ci>::type> type;
};
于 2013-02-21T13:16:51.180 回答